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SPARC CPU-2CE Technical Reference Manual 


Section 1 


1.0 INTRODUCTION 


A complete VMEbus-based SPARCstation™ 2 architecture with Sbus expansion. The SPARC CPU-2CE 
is the latest innovation resulting from the technology partnership of FORCE COMPUTERS and Sun 
Microsystems. Combining a true SPARCstation 2 architecture with FORCE COMPUTERS expertise and 
experience in standard 6U Eurocards has resulted in a faithful SPARCstation 2 implementation in a single 
VMEbus slot. 


The SPARC CPU-2CE™ offers the same I/O interfaces as the SPARCstation 2, including DMA supported 
SCSI and Ethernet ports along with audio, keyboard/mouse, and two serial channels with full modem 
support. Two Sbus sockets allow the installation of standard, off-the-shelf Sbus modules such as graphic 
frame buffers or accelerators or any other of over 300 Sbus cards available from third-party vendors. 


Through its binary compatibility with the Sun SPARCstation 2 family, the SPARC CPU-2CE runs current 
versions of SunOS™/Solaris™ as well as the more than 4,000 shrink-wrapped SPARCware™ applications 
available today. In addition, a variety of real-time operating systems will be available. 


Its IEEE 1014 compatible VMEbus interface enables the SPARC CPU-2CE user to build high-performance 
embedded UNIX® systems, SPARC®- based real-time systems and hybrid UNIX/real-time systems linked 
via the VMEbus or local- and/or wide-area networks. 


The SPARC CPU-2CE is a compact single board computer that brings the power and functionality of the 
popular Sun SPARCstation 2 to the industry-standard VMEbus for use in UNIX and real-time applications. 


OO 
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Figure: 1.1 Block Diagram 
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1.1 The Processor 


A 40-Mhz SPARC (Scalable Processor ARChitecture) 32-bit RISC processor chip set is at the core of the 
SPARC CPU-2CE. It is comprised of an integrated Integer Unit/Floating Point Unit (IU/FPU), a Sun 
standard SRAM-based Memory Management Unit (MMU+), a Cache Controller (Cache+) and two Cache 
RAM chips. Operating at 40 Mhz, the IU/FPU provides 28.5 MIPS integer performance and 4.2 MFLOPS 
floating point performance. The Cache Controller provides a 2-Kbyte tag array for a 64-Kbyte, virtual, 
write-through cache. 


The integrated CACHE+ Controller Cache/Memory Management Unit (CMMU) handles the cache 
memory, provides path to main memory over the SBus, handles SBus controller function, and works at 
40 MHz clock speed. The SPARC CPU-2CE has two cache RAMs that are 16K x 16 devices and run 
at 40 MHz clock speed. The large cache and double word write buffer means higher hit ratios and the 
ability to sustain high I/O DMA bandwidths with only a small reduction in local CPU performance. 


1.2 The Memory Subsystem 


The SPARC CPU-2CE chip set includes the RAM+, an Sbus-compatible DRAM controller with single 
clock burst capability. RAM+ operates the DRAM in fast page mode to support 8-, 16-, 32-, and 64-byte 
bursts at one transfer per clock after an initial access latency of 4 clocks for reads and 2 clocks for writes. 
The configuration supports up to 64 Mbytes of 32-bit wide DRAM on board and incorporates parity 
generation and parity error detection. 


The SPARC CPU-2CE is available with 16-, 32-, 48-, or 64-Mbytes of on-board DRAM. 16 Mbytes 
reside on the base-board and are implemented using high-reliability TSOP devices. Additional capacity, 
up to 64 Mbytes, is achieved using separate mezzanine modules which retain the single-slot capability 
without interfering with Sbus expandability on the SPARC CPU-2CE. Memory capacity upgrades are 
possible since the DRAM mezzanine modules are designed for field installation. 


Memory can be expanded beyond the 64-Mbyte on-board limit via ‘an SBus SRX-2 card. This option 
expands TypeO memory space by up to 64 Mbytes and is cacheable, an advantage over other Sbus-based 
memory expansion modules. 


1.3 System EPROM Open Boot™: 


The Open Boot™ EPROM on the SPARC CPU-2CE is located in a single 32 bit DIP socket that enables 
easy upgrading. It provides the functionality of the boot device supplied with the SPARCstation 2, with 
enhancements to support the added features of the SPARC CPU-2CE (VMEbus interface and optional 
Flash EEPROM). 


There is an EPROM-based monitor/debugger called Open Boot™, Open Boot is a trademark by Sun. 
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1.4 FLASH EEPROM (Optional Feature) 


In addition to the boot device, the SPARC CPU-2CE employs 4 FLASH EEPROMs in TSOP packages 
for flexibility and customization. This 1-Mbyte FLASH EEPROM is organized to be 32-bits wide and 
is mapped in place of the Sun SPARCstation 2 Sbus Slot 3. 


These EEPROMs are erasable and writable by the user and allow the system integrator to incorporate 
FCODE drivers for system specific VME-based products using routines supplied in the boot ROM. With 
150 ns EEPROMs, the access time is 4 clocks. 


The SPARC CPU-2CE allows integrators to specify their product as the console or boot device without 
having to modify the on-board firmware. It also allows them to take advantage of SunOS loadable drivers 
for their VME products. This feature provides a path to firmware-assisted system auto-configuration. 


1.5 Local /O 


Ethernet, SCSI interfaces, two serial interface ports, a keyboard specific serial port, a mouse specific serial 
port, a floppy disk controller, and an audio input / output port are provided. 


Serial Interface Ports 


The Zilog Z85C30 Serial Communications Controller (SCC) supports two serial interface ports using 
26-pin connectors on the front panel for synchronous and asynchronous communications. Data rates up 
to 64 Kbaud are supported and are user configurable, with a pluggable shunt for either RS-232C or 
RS-423C, and offer full modem control and interrupt capability. Both ports must be set identical as either 
RS-232 or RS-423. 


Keyboard/Mouse Port 


The connector for the keyboard/mouse port uses a SPARCstation Type 2 8-pin Mini-circular DIN 
connector on the front panel. The Z85C30 SCC for the keyboard/mouse specific port is terminated with 
TTL buffers and uses all TTL-compatible data signals. The interface is fully compatible with Sun 
SPARCstation 2 keyboard and mouse product offerings and uses the same cables. 


Floppy Disk Controller 


An Intel i82072 functions as the floppy disk controller and is fully compatible with the Sun SPARCstation 
2. The floppy disk controller signals are available on the User I/O lines of the P2 connector. 


Audio Port 


The audio interface is implemented with an AMD Am79CA30 ISDN/audio controller device and is fully 
compatible with the Sun SPARCstation 2. The audio connector on the front panel is an 8-pin 
Mini-circular DIN connector. As in the SPARCstation 2, the ISDN functionality of the Am79CA30 is 
not implemented. 


 —————— 
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1.6 DMA+ 


The DMA ASIC provides DMA and data assembly-disassembly functions for both the Ethemet and SCSI 
interfaces. The ASIC contains a 32 byte FIFO for each interface and performs DMA in 16 byte bursts 
when alignment and transfer length permit. 


1.7 Small Computer Systems Interface (SCSI) 


The SCSI interface provides a standard interface to a wide variety of mass storage devices, such as hard 
disks, tapes, and CD-ROMs. 


The SPARC CPU-2CE board features a Small Computer System Interface (SCSI) controller device using 
the NCR 53C90A controller chip augmented by the DMA+(D-channel). This provides SCSI-I 
functionality and can transfer at up to 5 Mbytes/sec, depending on the speed of the target. 


The SCSI controller on the SPARC CPU-2CE acts as a SCSI initiator. Up to seven SCSI target devices 
can be connected to a SPARC CPU-2CE board. The SCSI bus is properly buffered and terminated on 
the SPARC CPU-2CE, so that the connection of SCSI devices is simple and straight forward. Just attach 
a terminated SCSI device with a cable and the CPU-2CE will automatically adjust for proper termination. 


The DMA features full SCSI specification, ANSI X3.131/1986, compatibility. It supports both 
synchronous and asychronous operation with SCSIbus signals connected to the front panel connector and 
VMEbus P2 connector. Single ended mode is Supported only. 


The SCSI bus is routed to both the front panel, via a 50-pin SCSI-II connector, and to the board’s P2 User 
I/O pins. 


1.8 Ethernet Interface 


The Ethemet interface is comprised of the DMA-+ interface chip for DMA, the AMD Am7990 Local Area 
Network Controller (LANCE) chip and the AMD Am7992B Serial Interface Adapter (SIA). The IEEE 
802.3 Ethemet interface is available via a 15-pin Micro-D connector on the front panel. An adapter cable 
for the Micro-D to the regular DB15 is available. The DMA+ chip contains a 32-byte FIFO and increases 
performance through its 16-byte DMA burst capability. 


The Ethemet interface features compatibility to the IEEE 802.3 Ethemet specification, DMA burst 
capability, data rate of up to 10 Mbit/sec, interrupt generation (Level 6), and utilization of up to 128 
Kbytes of memory. 


1.9 Real-Time Clock/NVRAM 


The SPARC CPU-2CE board uses the Mostek MK48T08 RTC-NVRAM chip. This device includes an 
8-Kbyte non-volatile static RAM, of which 2 Kbyte is user programmable, and a Clock/calendar circuit. 
Both are supported by a 10-year shelf-life lithium battery, in order to retain data when the board is 
powered down. 


ese 
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1.10 SBus Interface 


The SBus is a high performance CMOS bus and the basic interconnection mechanism for the system 
between the CPU and main memory and I/O devices. Two Sbus connectors are available for I/O 
expansion into the next VME slot. 


The Sbus is a high-performance expansion bus with a bandwidth of over 50 Mbytes/sec. The Sbus forms 
the local memory and I/O bus for the SPARC CPU-2CE and features 32-bit virtual addressing, 28-bit 
physical addressing, 32-bit data path, synchronous data transfer and master/slave capability. The SPARC 
CPU-2CE incorporates two Sbus sockets for I/O expansion. These provide support and compatibility with 
the hundreds of third-party Sbus expansion products on the market, including products for video and 


graphics, connectivity and networking, manufacturing and process control, engineering, and scientific 
instrumentation. 


FORCE offers a 6U VMEbus Front Panel with two SBus board cutouts used to mount SBus boards to the 
CPU-2CE. 


1.11 VMEbus Interface 


The SPARC CPU-2CE utilizes the Sun VME Chip to provide a complete 32-bit VMEbus interface. Since 

this is the same device used on the SPARC CPU-1E from FORCE COMPUTERS system performance 

upgrades with minimal software changes are guaranteed. Supported functions include master and slave 

data transfer capabilities, and VMEbus interrupt handling and arbitration functions. Additional VMEbus 
- utility functions and a special loop-back cycle for standalone testing of the interface are provided. 


The VMEbus interface on the SPARC CPU-2CE is fully supported by a driver for the SunOS/Solaris 
operating system. The software support also includes an implementation of the ONC/VME protocol which 
supports standard networking protocols such as TCP/IP, NFS and RPCs across the VMEbus backplane. 
The VME Driver is needed to implement VME software. 


1.11.1 Master Interface 


The VMEbus master interface allows 16-, 24-, and 32-bit addressing with 8-, 16-, and 32-bit data transfers. 
A full 4-GByte address range is available and may be mapped contiguously without the 512-Mbyte 
limitation typically imposed by the 28-bit Sbus definition. This is done by directing normally unused 
MMU signals to VMEbus decoding logic, external to the VME chip. A software switch enables the 
standard VME 512-Mbyte address mode with window mapping registers. This 28-bit mode emulates the 
SPARC CPU-1E VMEbus addressing scheme, allowing customers a migration path to help preserve a 
previous investment in custom VMEbus drivers. 


Read-modify-write cycles are supported for master accesses, and a 300 psec VMEbus timer is included. 


NOTE: Unaligned transfers are not supported by the VME chip. 
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1.11.2 Slave Interface 


Access to the on-board DRAM is allowed to a 1-Mbyte page configurable on 1-Mbyte boundaries within 
the local address space. Addressing is recognized for both 32- and 24-bit standard accesses, with 16-bit 
accesses reserved for the mail box interrupt. Address modifiers are supported, and any slave access as 
a Direct Virtual Memory Access (DVMA) device is set to the local supervisor mode in accordance with 
the Sun-4™ architecture. The 1-Mbyte VME address space selected is always mapped to the highest 
megabyte in the virtual address space in accordance with the Sun-4 architecture. Unaligned slave accesses 
are not supported by the VME chip. See the chapter on the VMEbus Interface for more details. 


A mail box interrupt function allows other VMEbus devices to interrupt the SPARC CPU-2CE. This mail 
box detects accesses to the specific A16 address space set in the mail box register. Mail box accesses are 
acknowledged as standard VMEbus cycles, and trigger an on-board level 13 interrupt. 


1.11.3 Interrupts 


The on-board interrupt handler selectively supports all seven VMEbus interrupt levels which are routed 
directly to the MMU intermpt logic. Control of interrupts is handled via software in the interrupt enable 
register. 


1.11.4 System Controller 


The SPARC CPU-2CE is capable of providing Slot 1 system controller functions. The VMEbus requestor 
is a release on request (ROR) requestor. Bus requests are made on BR3. 


The VMEbus arbiter function is used when the SPARC CPU-2CE is configured for system controller 
functions (Slot 1 jumper). Both single-level (SGL) and round robin (RRS) arbitration are provided. Bus 
timer logic is included to prevent a VMEbus lockup to a non-responding bus requestor or to a non-existent 
slave device. 


Additional system controller functions are automatically activated, when the Slot 1 jumper is enabled. 
These capabilities include: IACK Daisy Chain Driver, SYSRESET, SYSFAIL and VMEbus system clock. 


1.12 Software Description 


With full SPARCstation 2 architecture compatibility, the SPARC CPU-2CE runs the Solaris operating 
system, including enhancements specific to the _ n SPARCstation product line. Solaris provides an 
advanced development and run-time environment for the SPARC CPU-2CE. As the first "shrink-wrapped" 
distributed computing solution, Solaris is comprised of SunOS, ONCO© networking environments, 
OpenWindows™, OPEN LOOK® and DeskSet™. SunOS is the highest quality and most widely 
supported enriched UNIX implementation available today. 


By carefully merging the most robust functionality of UNIX System V™, Berkeley BSD™, and Xenix™; 

SunOS offers the optimum balance of UNIX capability, reliability, and performance. Further functionality 

includes: 

» Standards Conformance (POSIX, X/Open, XPG, SVID and FIPS) 

* The OpenWindows "Look and Feel" Graphical User Interface 
eee 
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« Hierarchical and consistent format file system that includes support for MS-DOS®, CD-ROM and RFS, 
among others 


* ONC networking environment for distributed computing across multivendor networks 
+ Enhanced UNIX kemel with intemationalization, system accounting, security and redundancy 


¢ A comprehensive range of third-party software that include databases, design automation and artificial 
intelligence 


¢ VMEbus driver configured for Sun-4/SPARCserver™ type expansion interface allowing the use of 
existing Sun-compatible VMEbus device drivers . 

ONC is the industry standard for heterogeneous networking. OpenWindows is the network-extensible 
graphical application development platform. OPEN LOOK is an intuitive graphical user interface, and 
Deskset is a suite of personal and workgroup productivity applications. 


1.13 Development 


By using the SPARC CPU-2CE as both the development and the target system, equipment costs and 
time-to-market can be reduced. Solaris on the SPARC CPU-2CE provides all the tools necessary to take 
a project from conception through delivery. This includes: project planning aids (e.g. mail, diary, print 
facilities, etc.); design aids (e.g. compilers, assemblers, debuggers, and libraries); test facilities (e.g. 
compliance checkers, performance monitors, profilers, and system diagnostics); documentation tools (e.g. 
text formatters, print filters, and PostScript® interfaces); archiving and maintenance (e.g. source-code 
control systems, archivers, and backup systems); and others. 


Optimizing compilers available from Sun include: C, C++, FORTRAN-77, Pascal, Modula-2, and 
Common Lisp. Independent software developers furnish many other languages, including Ada, APL, 
BASIC, COBOL, Forth, Mainsail, PL/I, and Prolog. Sun languages have full access to systems, graphics, 
networking, and user interface packages. Third-party cross compilers allow C, FORTRAN, or Pascal 
programmers to produce executable binary code for multiple architectures from a single FORCE SPARC 
CPU-2CE. 


1.14 Sun Tools 


Standard software provided with Solaris includes a powerful user interface. This allows access to Solaris 
resource management functions, as well as industry- standard UNIX editors, command shells, and all 
UNIX commands for file management and manipulation, system administration, I/O system control, and 
other software development tools. 


1.15 Graphical User Interface 


OpenWindows is a full-featured windowing environment based on the X-Window Standard and the 
Network extensible Windowing System (NeWS™). OPEN LOOK is a graphical user interface that uses 
X-Windows and NeWS to provide an intuitive, "look and feel" desktop. The DeskSet is a group of 
personal productivity tools and system service applications which includes a File Manager, Calendar, 
Debugger, Mailer, and others. 
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1.16 Real-Time 


The SPARC CPU-2CE with Solaris, which supports a wide range of VMEbus and SBus-based hardware 
and software solutions, creates an ideal embedded system. New releases of Solaris will provide the 
SPARC CPU-2CE with real-time extension for use in "soft" real-time applications. These extensions 
include: fixed priority processes, Priority manipulation, pre-emptive scheduling, process priority 
inheritance, guaranteed dispatch latency and memory locking. 


Several hard real-time operating systems are available for or are being ported to the SPARC CPU-2CE. 
These typically provide high-speed multi-tasking, pre-emptive scheduling, and fast interrupt response. ~ 
They include facilities for intertask communications and synchronization, efficient memory management, 
system clock and timing, optimized floating point support, and high-performance I/O and file systems. 
Real-time development tools usually include an interactive debug Shell, a linking loader, symbolic 
debugger, performance monitor, exception and signal handling, libraries, utility routines, extensive system 
and task information utilities, and source level debuggers. 


1.17 Networking 


ONC networking environment is a suite of software modules and services that are the de facto standard 
for distributed computing. FORCE COMPUTERS provides a VMEbus driver utility as a standard item 
in conjunction with the Solaris operating system. This driver combines the standard Sun-4 SPARCserver 
treatment of the VMEbus expansion interface with the additional capability to run ONC over the VMEbus 
backplane. This provides an optimal platform for both tightly coupled networking and distributed 
processing applications, as well as the ability to utilize existing drivers for add-in VMEbus peripheral 
controllers. 


The Remote Procedure Call (RPC) is the core of ONC and is used to build services such as the Network 
File System (NFS™), Network Information Service (NIS) and Network System Boot. 


Solaris also supports an extensive set of networking tools that allow developers to take advantage of 
industry standards. Solaris supports intemet protocols, including raw (IP), datagram (UDP/IP) and stream 
(TCP/IP). User-accessible interfaces allow development of custom interfaces and protocols. Sun will also 
offer a Solaris Serial Line Internet Protocol (SLIP) for serial line_based wide-area networks (WANS). 


Optional software provides support for: DECnet; SNA, including IBM’s Advanced Program-to-Program 
Communications (APPC) and Document Interchange Architecture (DIA); OSI support which adheres to 
MAP 2.1 and TOP 1.0 specifications, Layers 1 through 7 for MAP applications; FTAM (File Transfer 
Access and Management); and CASE (Common Application Services Elements). 


eee 


Page 1-10 FORCE COMPUTERS 


“SPARC CPU-2CE Technical Reference Manual Hardware 


Table: 1.1 Board Function & Specification 











Central Processing Unit 










28.5 MIPS 

4.2 MFLOPS @ 40 MHz Double Precision 
50 Mbytes/sec (80 Mbyte/sec peak) 

64 Kbytes 


a 13 |e 
ae ie) 
|i | 2 
zi lz 
213 (8 
B I< 
8 


a 
8 
ie 
2 
y 
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Byte Parity 

16, 32, 48 via mezzanine 
64 Mbytes 

8 Kbytes 


mi wsia 
a |2/8 
a |a | 
VICE 
8 y 
7cab 
81/4/2 
ao i15' 
£8 
a] 
Qa 
p | &. 
318 
S 


Local DRAM Expansion (Single Slot) 
Maximum On-Board DRAM 
SRAM (Battery Backed Up) 


SBus Expansion 


32-bit IEEE/ANSI-standard 

A32, A24, A16: D8, D16, D32, RMW 
A32, A24: D8, D16, D32, RMW, BLT 
1 through 7 (Selectable) 

4 level SGL 

Yes (A16 access) 

7990 Lance, AMD 7992B SIA 

10 Mbits/sec 

NCR 53C90A and DMA+ 

ASYC 1.5 Mbyte/sec, SYNC up to 5 Mbyte/sec 
2 Async/Sync; RS-232-C/RS-423 

64 Kbaud 


VMEBus Master 

VMEBus Slave 

VMEBus Interrupt Handler 
VMEBus Arbiter 





Multiprocessor Mailbox 
Ethernet (IEEE 802.3) 
Ethernet Transfer Rate 
SCSI Controller 

SCSI Transfer Rate 
Serial Ports 









i 


Serial Data Rates 
NVRAM TOD Clock/Calendar MK 48T08 

EPROM Size 2 Mbyte, 8-bit wide 
FLASH EEPROM Size (Optional Feature) | 1 Mbyte, 32-bit wide 


w 


eset Switch Yes 
Abort Switch Yes 
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Audio Controller 


[Audio Commuer 


2A Minifuse Schurter P/N 3402.0012.xx 
630ma Minifuse Schurter P/N 3402.0008.xx 


JNumberofVMESisUed [a 
6.29" X 9.18" (160 x 233 mm) 





See the ordering information table on the next page for adapters available from FORCE. Contact your 
local sales office for additional options. 
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Table: 1.2 Compatible Peripherals 














1/2" cartridge drive 
FFioppy Deve ([Soyrirwerr tae 
Fiard Drive | Maxtor ixT-2i3sy___| 210 MB 3 1/2 inch SUN 207 









* Not in SUNOS 4.le 
** Not in SUNOS 4.1.1b 
*** Only Supported in SUNOS 4.12 


1.18 Determining Revision Level 


You can determine the revision code and serial number of a SPARC CPU-2CE by inspecting the label 
attached to the P1 connector of each card. 
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Section 2 


INSTALLATION and DIAGNOSTICS 


WARNING 


TO AVOID MALFUNCTIONS AND COMPONENT DAMAGE, PLEASE READ THE COMPLETE 
INSTALLATION PROCEDURE BEFORE THE BOARD IS INSTALLED IN A SYSTEM 
ENVIRONMENT. 


STATIC KILLS 


ee 
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2.1 Power Up 


This chapter will cover the instructions and considerations for powering up to insure proper operation of 
the CPU-2CE. 


The only mechanical jumper blocks for the CPU-2CE are to configure the serial ports and to configure 
the VME. The serial ports are RS-232-C or RS-423 with the default being RS-232-C. If RS-423 is 
needed, set the block before power up. Move the jumpers position to set RS-423. Both ports must be 
set identical as either RS-232 or RS-423. The VME default is VME slot 1 device with the jumper 
installed in JMP1. Removing Jumper 1 selects the card to be non-slot 1 VME device. VME backplane 
must be terminated according to spec. 


Backplane Slot Configuration Requirements 


The SPARC CPU-2CE can be plugged into any VMEbus slot. If a SPARC CPU-2CE is installed in a 
slot other than 1 with empty slots between it and the slot 1 controller. Each of the empty slots must be 
configured as described below. See your backplane manual for documentation on the location of these 
jumpers. 


Jumper IACKIN* to IACKOUT* on the backplane: 

Pins A21 and A22 on the backplane must be jumpered together. 

The signals Bus Grant [0:3] must be jumpered across empty slots, as follows: 

BGO: jumper pins 4 and 5 Row B 

BGI: jumper pins 6 and 7 Row B 

BG?2: jumper pins 8 and 9 Row B 

BG3: jumpered pins 10 and 11 Row B 

The CPU-2CE can power up without a computer terminal and keyboard, but you cannot enter the 
appropriate commands to test the card without a means to enter commands and view the results. FORCE 
recommends the initial power up to be performed with a computer terminal connected to serial port A of 
the CPU-2CE. By using the computer terminal, additional possible error producing factors; a 
nonfunctioning SBus card, SBus frame buffer cai. 2onnector, or monitor can be detected. Connecting a 


terminal is simpler than connecting a frame buffer, monitor, and keyboard. The optional serial cable is 
available by ordering the accessories kit. 


NOTE: Make sure you use a terminal type serial cable. See your terminal manual for ordering or 
building the proper cable. 


The power-up sequence consists of a series of component functional tests and initialization, followed by 
booting. Tum on the power to the backplane. 


In the default autoboot mode, the SPARC CPU-2CE attempts to boot SunOS from an attached SCSI disk. 
If a disk is not attached, the Open PROM displays an identification banner and enters the command mode 
of the "PROM Monitor" (a program that monitors the activity of the keyboard). The PROM displays a 
> prompt. 
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Figure: 2.1 RS-232/423 Jumper Blocks 


BOARD JUMPERS 





FORCE COMPUTERS Page 2-3 


Hardware SPARC CPU-2CE Technical Reference Manual 


2.2 Post Power Up Procedures 


2.2.1 How to Talk to the SPARC CPU-2CE On-Board Memory 
At the > prompt type 1 to enter "New Mode" the FORTH/OpenBoot interpreter. 


FORTH displays the ok prompt. Basic Assembly PROM commands are available to the SPARC 
CPU-2CE in this interpreter. Enter the following command at the OK prompt. 


0 obmem 0 map-page <cr> to map in the first 4K bytes of main memory. 

There is at least 16MB of onboard memory available to the SPARC CPU-2CE card. The first test of the 
SPARC CPU-2CE PROM validates correct operation of this memory. Use one of the three commands 
explained below: 

2.2.1.1 Memory Test Command One 

Perform a LOOP/READ that validates that the on-board memory is functional: 

At the ok prompt type 100 50 dump <cr> 

RESULTS: If the PROM and the on-board memory are functional, the contents of the 80 bytes (50 hex) 


of memory starting at address 100 (hex) are displayed. If the PROM or the on-board memory is not 
working, you receive one of a number of possible error messages indicating a problem with the memory. 


2.2.1.2 Memory Test Command Two 


Perform a LOOP/WRITE that writes a number pattern to memory, validating memory and memory 
response: 


At the ok prompt type 100 50 78 fill <cr> 


RESULTS: If the SPARC CPU-2CE is working correctly, the number pattem "78" is written to 80 bytes 
of memory starting at address 100, and you will receive the ok prompt. The fill command fills byte by 
byte. If the PROM or the on-board memory is not working correctly, you receive one of a number of 
possible error messages indicating a problem. 


eer eee 
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2.2.1.3 Memory Test Command Three 


Perform a memory test that exercises the on-board memory. This test does not reside in the PROM, and 
must be keyed in at the FORTH prompt. (Memory must be mapped according to section 2.2.1) 


Key in the following program: 


: memory-test ( -- ) 
150 100 do- \from 0x100 to 0x150 
12345678... 2! \longword write 
i 1@ dup \longword read (result left 
\on stack) 
12345678 <> \compare 


t£ .",0obs =". 
." exp = " 12345678 
oY adr = "4a. Cr 
then 
drop 
4 +loop 


When this code has been correctly entered, you can perform the memory test: 
memory-test <cr> 
Also, the following command runs the Open Boot memory test: 
test /memory or test-memory 


This test is the same as the Open Boot POST test and will take approximately 4 minutes for 32 
megabytes. 


RESULTS: If the SPARC CPU-2CE is working correctly, the memory is erased and tested, and you will 
receive the ok prompt. If the PROM or the on-board memory is not working correctly, you receive one 
of a number of possible error messages indicating a problem. 


Connect the cables for the additional devices you wish to test with the SPARC CPU-2CE: SCSI, 
Keyboard, Ethernet, Serial Ports A and B. (Make sure the power is off before connecting any cables to 
the CPU-2CE.) 

2.2.2 Test the Ethernet Port 

Test the Ethernet port by connecting a MAU (Medium Access Unit) to the Ethemet port and while in 
Forth/OpenBoot and typing: 


test net <net> 


. —-'_[00£0wOw ee ee en 
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2.2.3 How to Talk to the SPARC CPU-2CE Buses 

Access to the devices available on the SPARC buses in general requires mapping, reading, and writing 
the device. This test is performed only when testing an SBus memory card. The procedure below can 
be used to map in memory. Devices are mapped in two stages: 


2.2.3.1 Mapping Memory 


Select unused segments, virtual address range and size. Map in the segments, e.g., seg# = 0x80, va = 
0x1000000, size = 0x4000. 


80 1000000 0x4000 map-segments <cr> 


Select a physical address range and space (SBus Slot2). Map in the page e.g., pa = OxFC000000, space 
= SBus. 


FC000000 sbus 1000000 4000 map-pages <cr> 


2.2.3.2 Accessing Memory 


To dump out memory at the ok prompt type 1000 000 50 Dump <cr> 


2.2.4 How to Talk to the SBus 


SBus devices are handled using the IDPROM onboard the SBus card. The IDPROM contains a driver 
for the SBus card which is read at boot time and interpreted by the Open PROM. During debug of an 
SBus device or it’s driver a device in an SBus slot may be mapped in using map-sbus. (See the Open 
PROM Toolkit User’s Manual for a description of the map-sbus). 


2.3 Running PROM Diagnostics 


Setting the diagnostic switch and resetting the card will cause the card to come-up into the extended 
selftests. 


CAUTION: This command disables the monitor and keyboard and enables Serial Interface A as the 
I/O device. 

type: setenv diag-switch? true <cr> 

reset type: reset or lift the reset switch on the front panel. The board will exit automatically. 


NOTE: You must have a tty device attached to Serial Port A. Setting the diag-switch to true puts 
messages to the serial port A console. 


SS SSS sssssssSsssnsssnssssnsess 
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2.4 Running Functional Tests 


The following tests are available for testing functional units on the CPU-2CE. These tests are 
automatically run at a reset or a power-up. 


The functional test can be run individually by leaving the PROM monitor and entering the 
FORTH/OpenBoot interpreter. 


At the > prompt, enter n. 
At the ok prompt, enter one of the following commands. 
test /memory or test-memory 
test /sbus/le 
test net 
test floppy (requires floppy drive and Sun formatted FD formatted disk) 
watch-clock 


probe-scsi 


NOTE: For a complete listing of diagnostics available from the PROM, type help diag or help test 


2.5 Returning To Monitor Mode 


To retum to the > prompt from the OK prompt, 
enter the following: 


ok old-mode <CR> 


2.6 Diagnostics 


This chapter describes the different types of diagnostic firmware and software tools available and how they 
are related. 


2.6.1 Main Categories of Diagnostics 
¢ Boot PROM diagnostics 
Power-On Self-Test 
On-Board Diagnostics 
¢ Sundiag System Exerciser (SunOS) 
This chapter will also briefly cover the Forth/OpenBoot Toolkit, which is an interactive command 


interpreter based on the Forth programming language. Additional information on the Sun Forth Toolkit 
can be found in the Open Boot PROM 2.0 Toolkit User’s Guide in the SBus Developers Kit. 
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2.6.2 Diagnostic Selections 


Table: 2.1 Diagnostic 7 Tools 


[Piaposic Toot 


Power On Self Test The POST code resides in the boot PROM and is driven automatically by 
(POST) a signal from the power supply when first powered on. The CPU 
performs the self-test. POST shows if there is a failure of the main 
components on the main logic board. 






























Individual test, ie memory, Ethemet, etc., available when in Forth 
Toolkit. Enter n from the > prompt to enter the Forth Toolkit. The on 
board diagnostics reside in the boot PROM. 


On Board Diagnostics 

















Using SunOS, it displays realtime use of system resources and 
peripherals. Sundiag will show if your system is functioning properly. If 
Sundiag fails, run the Power On Self Test. 


Monitor will be activated when the system crashes. Monitor is the > 
prompt. Typing 5 boots, ¢ resumes or continues program halted, or n to 
enter Forth Toolkit. 


Performs all functions available through the Monitor, except entering the 
Forth Toolkit i.e. changing the NVRAM parameters, resetting the system, 
running diagnostics, displaying system information, redirecting input and 
output, etc. There is more in this chapter and the Open Boot PROM 2.0 
Pp Toit User’s Guide. 


Sundiag System 
Exerciser 
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Figure: 2.2 POST 


FIGURE 2.3 Power On Self Test Flow Chart 
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The Forth Toolkit offers an extensive set of functions for performing the following: 

¢ Hardware Development 

e Problem Determination (fault isolation) 

¢ Software Development 

¢ Debugging 

This section will detail how various diagnostic tools work together in different power on modes. 
NOTE: A terminal is needed to view these test results. 

CAUTION- To run the On-Board Diagnostics the system must be halted. When the operating system 


or application has been booted, do not use the L1-A keys to halt the system. L1-A abruptly halts the 
system and may damage data files. As root halt the system by entering /usr/etc/shutdown or /etc/fasthalt. 


° When the power is turned on, the lower level Power On Self Test (POST) code is executed from 
the Boot PROM. 

° If failure occurs in POST, the type 4 keyboard LEDs will display the failure code. See The Power 
On Self Test in this section for more detailed information. 

° If the POST passes, the system probes for SBus devices and interprets their drivers. 

° High level test are performed next. 

2 Specialized diagnostic test can be performed after the high level test by activating the Monitor, 


indicated by the > prompt. The monitor is activated by pressing the L/] and A keys 
simultaneously and waiting for the > prompt. 


° If the autoboot switch parameter is set to false (not the default) the > or ok prompt will show. 
The monitor with its prompt > is the default. It is possible to change the default to the 
Forth Toolkit with its prompt ok as an option, see the Open Boot PROM 2.0 Toolkit 
User’s Guide. 


° If the autoboot switch parameter is set to true (default), and the diagnostic switch parameter is set 
to false (default), SunOS boots from the default SCSI target 3 boot path: 


/sbus/esp/sd@3,0 
If the hard disk address is set to 0, then the boot parameter should be set to /sbus/esp/sd@0,0. 


° For normal booting boot /sbus/esp will automatically find and boot the disk. 


eee 
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° If the autoboot switch parameter is set to true (default), and the diagnostics switch parameter is 
set to true (not the default), SunOS boots from the bootpath: 


/sbus/le 
° To boot user-specified programs, such as the SunDiagnostic Executive, you must be at the > or 


ok prompt. On Board Diagnostics section later in this chapter will detail how to obtain the > and 
ok prompts with fasthalt. 


Diagnostic 
Switch 


True 


boot SunOS (vmunix) 
from SCSI ID 3 
(/sbus/esp/sd@3,0) 





* The boot parameters represented here are default settings. The defaults may be changed by following 
the procedures listed in the Open Boot PROM 2.0 Toolkit User’s Guide. 


2.6.3 Boot PROM Diagnostics 
The diagnostics contained in the boot PROM include the following: 
Power-On Self-Test 


On-Board Diagnostics 


2.6.3.1 POST 


The Power On Self Test (POST) is the default mode. The POST consist of a sequence of test designed 
to test the major hardware components of the main logic board before SunOS is booted. Only major 
failures can be detected by POST. For additional more thorough diagnostics run the extended on-board 
diagnostics for items including Memory, Ethemet, diskette drives, etc. 


ee 
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Figure: 2.3 Keyboard LED Diagnostic Codes 
Arrangement of Sunt Keyboard LEDs 
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Sun4 Keyboard LED Diagnostic Code 
Meaning of Pattern 


Unassigned. Testing completed, SunOS is 
booted. 
tech Bad checksum In boot PROM. 











NVRAM/Time-of-Day Clock failed. 
SPARC 2 SPARC 2 component failed. 
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2.6.3.2 On Board Diagnostics 


1. Save all your work and quite all applications 
2. As root, halt the system by entering 


/usr/etc/fasthalt 


The returning prompt will either be a default prompt > or the prompt ok. To change the prompt see the 
Open Boot PROM 2.0 Toolkit User’s Guide. 


If you see the > prompt, go to the next step. If you see the ok prompt go to step 4. 
3. Enter n to enter the Forth/OpenBoot Toolkit. 

The ok prompt signifies the Forth Toolkit mode. 

4. Enter help diag to get a listing of on-board diagnostic test. 

5. To return to the monitor > prompt, type the following command 


old-mode 


2.6.4 Sundiag System Exerciser 


The Sundiag System exerciser verifies that the system is functioning properly. Sundiag runs under SunOs 
and displays real-time use of system resources and peripheral equipment such as Desktop Storage Packs 
and External Storage Modules. 


Exerciser is shipped with SunOS. If it was selected during Sunlnstall (operating system loading) 
procedure, it can be run at any time. The file is found in the directory /usr/diag/sundiag. The file can 
also be loaded from tape or CD. You must also have Sunview and the file userdiag loaded on your disk. 
Become root on your system then type sundiag. See the Sundiag User’s Guide for further information. 


2.6.5 Monitor and Forth Toolkit 


The Monitor is a basic diagnostic utility. If there is a problem with the operating system the Monitor will 
automatically start, indicated by the > prompt. 


SS 
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Table: 2.3 Non-Volatile System Configuration Parameter Defaults 
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1 
last-hardware-update 
fase 















Table: 2.4 NVRAM VME Configuration Parameters 


rerun mailbox level register 
Bus locker register 
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2.7 SPARC CPU-2CE NVRAM Parameters 


This section lists and defines the NVRAM parameters unique to SPARC CPU-2CE architecture. Each 
parameter will be presented in the following format: 


parameter [options][default] 
parameter and a description of the parameter’s function. 


vme-slavemap [range:0-15}[0} 
vme-slavemap selects a one megabyte space for system DVMA access. vme-slavemap will select 
one of the first 16 MB of VME space. 


vme-a32map [0x0,0x20,0x40,0x60,0x80,0xa0,0xc0,0xe0)][0] 
vme-a32map remaps VME address bits A[31:29] enabling full 4GB mapping. 


vme-intena [0-255][254] 
vme-intena selectively enables VME interrupt levels by setting a bit mask that corresponds to the 
Interrupt Enable Register. The default value of Oxfe enables all interrupts and disables 
Round-Robin Arbitration. 


vme-mailbox [0-255][0] 
vme-mailbox selects a VME address to be monitored. If enabled, generates a mailbox interrupt 
to the IU by way of an on-card interrupt. This mailbox detects accesses to Al6 address space at 
a location programmed in the Mail Box register. No real memory is provided at this location, but 
the mailbox responds with a VME DTACK, acknowledging the access and generating a level 13 
interrupt if the enable bit is set. 


vme-buslock [0,1][0]] 
vme-buslock is a bus locker function that enables the CPU to do an Atomic Read-Modify-Write 
(RMW) to its on-card memory without being interrupted by an incoming RMW form another 
VMEbus master.. This parameter should only be used in a multiprocessing environment. 


vm_-server-slavemap [0-15][0] 
vm-server-slavemap sets the slavemap location of the client’s server. See the SunOS 4.le Release 
Manual, ONC/VME and the description of vme-slavemap above. 


vm-server-address [internet address][0] 
vm-server-address is the internet address of the client’s server. This address is made up of four 
hexadecimal numbers expressed in decimal form. For example, the number 199.9.9.1 (all decimal 
numbers), converts to the hexadecimal value 0xc7090901. See the SunOS 4.1e Release Manual, 
ONC/VME. 


vm-ip-addr [internet address][0] 
vm-ip-addr is the internet address of the client. This address is made up of four hexadecimal 
numbers expressed in decimal form. For example, the number 199.9.9.1 (all decimal numbers), 
converts to the hexadecimal value 0xc7090901. 


ee eee 
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Table: 2.5 Front Panel 
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Figure: 2.4 Font Panel 
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Figure: 2.5 Component Side 
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Figure: 2.6 Solder Side 
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Table: 2.7 | yi SCSI Pinout List 
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Figure: 2.7 SCSI Connector and Pins (Front View) 
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Ethernet Connector Pinout List 


The following table is a pinout of the Ethernet connector. Figure 2.8 Shows the Ethernet connector and 
pin numbers. 


Table: 2.8 Ethernet Pinout List 











Figure: 2.8 Ethernet Cable Connector and Pins (Front View) 
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Table: 2.9 Serial Pinout List 


3 RxD- Receive Data 
CTS-Clear to Send 


20 i DCD-Data Carrier 
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24 TRXC-DCE Transmit 
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DATE OF PURCHASE: ORIGINATOR: 
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PRESENT DATE: 


THIS AREA TO BE COMPLETED BY FORCE COMPUTERS: 








DATE: 
PR#: 


RESPONSIBLE DEPT.: 





___ ENGINEERING 
~__ MARKETING 
___ PRODUCTION 


AFFECTED PRODUCT: 





AFFECTED DOCUMENTATION: 











___ HARDWARE 
___ SOFTWARE 
___ SYSTEM 


ERROR DESCRIPTION: 


___ HARDWARE 
___ SOFTWARE 
___ SYSTEM 






Please send this product error report to one of our nearest FORCE COMPUTERS offices: 


FORCE COMPUTERS Ine. FORCE COMPUTERS GmbH 
2001 Logic Drive Prof.-Messerschmitt-Str. 1 

San Jose, CA 95124 D - 85579 Neubiberg/Munich 

U. S. A Germany 

FORCE COMPUTERS FRANCE S.A.R.L. FORCE COMPUTERS UK Ltd. 
Le Volta No. 1 Holly Court 

17-19 rue Jeanne Braconnier 3 Tring Road 

F-92366 Meudon La Foret Cedex Wendover 


Buckinghamshire HP22 6PE 
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Reader Comment Card 


Strongly Suongly 
: Agree Agree Neutral Disagree Disagree 
Please circle one number for cach. ° 


¢ The manual is well organized. 1 2 3 J 6 
¢ Instructions are complete. 1 2 3 5 6 
° The manual is clearly written. 1 2 3 5 6 
° Dlustrations are clear and helpful. 1 2 3 5 6 
*¢ The manual contains enough illustrations. 1 2 3 5 6 
¢ Layout and format enhance the manual’s 1 2 3 5 6 
usefulness. 
° This manual meets my overall expectations. 1 2 3 5 6 


Please write additional comments, particularly if you disagree with a statement above. Use additional pages if 
you wish. The more specific your comments, the more useful they are to us. 


Comments: 


Optional Information- 


Name: 





Title: 





Company: 





Address: 





City/State/Zip: 





Phone: 





Thank You 
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Keyboard Out 
Keyboard In 


Ground* 





* All signals TTL Levels. +5V current-limited. May be jumpered to Mouse Output. 


Figure: 2.12 Keyboard/Mouse Connector 
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Table: 2.13 P1 Bus Pinout List 
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Table: 2.14 P2 Bus Pinout List 
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SCSI_LDATA7 
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Expansion Connector Mechanical Layout 


The Expansion Connector is an 8-pin header on 0.1” centers with the following pinout: 


Frin# | Function | eon a ; 7 ae 
| Pin# Function Signal Description 


[1 |Pas | SBus physical address line 26 
A 20 MHz clock for a SS-2 ram controller. It has a 25-75 duty cycle. 


Second ram controller chip select. Asserted low whenever a virtual 


address translates to a legal page in TypeO address space between 
Logic ground forthe system 


0x8000000 and OxFFFFFFF (pa27 high). 

5 ParCS1* Parity register chip select for second ram controller. Asserted low 
whenever a virtual address translates to a valid page in Type] space 
with a physical address of OxF4000008 - OxF400000F. 

RamClk A 20 MHz clock for an SS-2 ram controller. It has a 75-25 duty 
cycle. 
[7 | Pa2s _| SBus physical address line 25. 
Parity Error signal. This open drain signal is similar to the SBus 


signal LErr* except that it must meet SBus timings with the data in 
error, rather than one clock later. 
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Section 3 


HARDWARE 
3.1 Card Landmarks 


Figure: 3.1 Shows the Front Panel 


Figure: 3.2 Shows the component-side of the SPARC CPU-2CE card with various 
call-outs pointing to the card landmarks. 


Figure: 3.3 Shows the solder side of the FORCE SPARC CPU-2CE 
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CPU-2CE FRONT PANEL 
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CPU-2CE Front Side 
Connector Rotary Switch 


of 
Hp 4 





Stiffener 
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CPU-2CE Back Side 


O00 O O0 


Stiffener 
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3.1.1 Card Jumpers 


The only mechanical jumper blocks for the CPU-2CE are to configure the serial ports and to configure 
the VME bus system controller functions. The serial ports are linked so both ports are either RS-232-C 
or RS-423 with the default being RS-232-C. If RS-423 is needed, set the block before power up. Move 
the jumpers position to set RS-423. The VME default is slot one with the jumper in. See the example 
below and on the next page for the CPU-2CE defaults. 


Serial RS232 VME SLOT 1 


ee 
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Figure: 3.4 RS-232/423 Jumper Blocks (Ilustrations shows the default RS-232 setting) 


BOARD JUMPERS 
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Figure: 3.5 SPARC/CPU-2CE ADDRESS SPACE VIRTUAL Physical Memory Map: ASI Program 


Figure - Physical Memory Map: Device Space 












OxFFFF FFFF 


Address Space Identifiers (ASI) Type 1 Device Space 


ASI: 


Defined on the Next 
Page 


OxF000 0000 


| 4 GB Address Space (Ideal) 


OxOFFF FFFF 


Type 0 Device Space 


Off-Card Main Memory 
On-Card Main Memory 


0x0000 0000 
SPARCengine 2 User's Guide - December 1990 


a 
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Figure: 3.6 Physical Memory Map (see page 64 for LED’s, Hexswitch, and (Optional Feature - Flash 
maps) 


Figure - Physical Memory Map: Type 1 Device Space 


OxF8CO 0002 Ethernet Address 
CO 0000 Ethernct Data 












ration-2 


OxFC00 0000 


OxFFFF FFFF OxFA00 0000 

















SBus Slot 0 Device Space Byte Count 
Address 
OxF840 0000 DMA ControV/Status Reg. 
OxF740 0000 Auxiliary 1/O Register 
OxF720 1000 Audio Control Register 
OxF720 0001 Floppy FIFO a 2 
OxF720 0000 Floppy MSR/DKS Reg 


OxF600 0100 
OxF600 0000 EPROM Data 


OxF400 000C Memory Control (off) 
OxF400 0008 Memory Error (off) 

OxF400 0006 Memory Control (on). 
OxF400 0000 Memory Error (on) 


OxF300 000C Limit 1 Register 
OxF300 0008 Counter 1 Kegister 
OxF300 0004 Limit 0 Register 

OxF300 0000 Counter 0 Register 


OxF200 O7FF Year 

OxF200 07FE Month 
OxF200 07FD Date 

0xF200 07FC Day 

OxF200 07FB Hour 
OxF20007FA Minutes 
OxF200 07F9 Seconds 
OxF200 07F8 TOD Control 


OxF200 07F7 
OxF200 0000 NVRAM Data 


OxF100 0006 Scrial Port A Data 
OxF100 0004 Scrial Port A Control 
OxF100 0002 Serial Port B Data 

0xF100 0000 Serial Port B Control 


0x0100 0006 Keyboard Data 
0x0100 0004 Keyboard Control! 
0x0100 0002 Mouse Data 

0x0100 0000 Mouse Control 


OxF800 0000 


Floppy/Audio Registers 





Interrupt Control Register 
Memory Registers 


0xF500 0000 


OxF000 0000 







Counter/Timer Registers 


NVRAM/TOD Clock 















Serial Port A & B Registers 






Keyboard/Mouse Registers OxFO00 0000 


Address Busses & Address Spaces 


ere 
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Virtual memory Layout is OS dependent. For SunOS 4.1.1 the information can be obtained from the .H 
files included with SunOS. This SunOS 4.1.1. example is from the file machdep.c but, this information 


will change for Sun Solaris and other operating systems. 
| Table: 3.1 Virtual Memory Layout 


SUN OS 4.1.1 
= 



























OxFFFFA000 _ NPMEG-2 
memory error reg 
OxFFFF9000 _ 
eeprom, idprom, clock 
OxFFFF8000 _ 
counter regs . 
OxFFFF7000 _ 
auxio reg 
OxFFFF6000 _ 
DVMA IOPB memory 
OxFFFO0000 _ _ DVMA 
OxFFEF0000 _ 
ORFFESOO00 _ 
monitor 
OxFFDO00000 _ és 
MONSTA 
RT 
debugger 
OxFFCO00000 _ a 
DEBUGST 
ART 
SEGTEMP2 
OxFFB80000 _ 
NCARGS + MINMAPSIZE 
OxFF880000 _ _ Syslimit 
OxFF000000 _ Sysbase 


Sysmap and other kemel virt addresses 
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configured tables buffers 


trap table (4k) _ 


user copy red zone 
(invalid) 


user stack 
user data 











0x00002000 _ 






0x00000000 





senses 
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Table: 3.2 Address Space Indicator Contents 


oo) imeem gg tn ae oe ola ae Ca 
a a ae RR 
oa Syne ge mt See | Sp Gor Sa 
Fons [Segmen Map comma race | MMU Com Sac 


3 
OxS High Speed Segment Flush Control Space Main Memory Cache 
Control Space 
High Speed Page Flush Control Space Main Memory Cache 
Control Space 
0x7 High Speed Context Flush Control Space Main Memory Cache 
Control Space 
























Flush Cache by Page Control Space Main Memory Cache 
Control Space 

OxE Flush Cache by Context Control Space Main Memory Cache 
Control Space 

OxF Hardware Virtual Flush Control Space Main Memory Cache 
oan Control Space 


| OxC Flush Cache by Segment Control Space Main Memory Cache 
Control Space 


3.1.2 Device Space 


Device Space consist of MMU-mapped main memory and I/O devices that are accessed through translation 
physical addresses. 


The CPU automatically sets the ASI bits correctly for accesses to device space user data/instruction and 
supervisor data/instruction. 


a eee UE EEE EEE ESS 
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3.1.3 Control Space 


Control Space is all non-device spaces. Control Space is accessed only in supervisor mode. Control 
Space is sub-divided into System Control Space, Main memory Cache Control Space, Memory 
management Unit Control Space. 


The System Control Space contains control and status registers, serial port bypass, and cache tags. The 
System Control Space accesses can only be done using altemative space instructions. System Control 
Space is not mapped. 


rena 
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Figure - Physical Memory Map: System Control Space 


OxFFFF FFFF 









Address Space Identifier (ASI) o Serial Ports Control Register OxF000 0000 


i 


ASI Value: 2 is 
OxFFFF FFFF--~ 


0x9000 FFFF 


24 0x9000 0000 
0x8000 FFFF 











g 
=) 
Ou 
WY 
i x 
17) 
est 0x8&000 0000 
uo} 
2 |g 
6 rs Diagnostic Register (Unused) 0x7000 0000 
4 E 
4 ~ 
{ g Async Error Data Register (Doubleword) 0x6000 0014 
i) Async Error Data Register (Single word) 0x6000 0010 
Asyne Error Location Register 0x6000 000C 
Async Error Control Register 0x6000 0008 
eae Sync Error Location Register 0x6000 0004 
0x0000 000 Sync Error Control Register 0x6000 0000 
aly System Enable Register 0x4000 0000 
Mask 
Context Register 0x3000 0000 
ID PROM (Unused) 0x0000 0000 


Address Busses & Address Spaces 


FORCE COMPUTERS Page 3-13 


Hardware SPARC CPU-2CE Technical Reference Manual 





Figure: 3.7 Virtual/Physical Memory Map ASI Diagram 


Figure - — Virtual/Physical Memory Map: ASI Diagram 


Address Space Identifiers (ASI) 


ASIVaue: 0 1 2 3 @ 5&5 6 7 8 9 0 NH 2 8 UW 145 
0 FFF FF FE 


High Speed Page Cache Flush 
High Speed Context Cache Flush 


Segment Cache Flush 
Context Cache Flush 
Virtual Cache Flush 


ir. 
o 
S 
z 
6 
< 
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3.1.4 The Memory Map Page 


F0000000 


F 1000000 


F2000000 


F3000000 


F4000000 


F5000000 


F6000000 


F7000000 


Figure: 3.8 Type 1 Space (On-Board I/O) (obio) 


Keyboard/Mouse 


Parity Ctrl 
RAM+Ctl 


Internal Controller 







i82072 (FLOPPY) 
AMD 79Ca30 
(AUDIO) 
1/O Register 








SBus Slot 0 
F8000000 
F8400000 
F8800000 


F8C00000 


FA000000 


FC000000 


FF000000 


FF800000 





SBus Slot 1 


—_ 


SBus Slot 2 


| 


SBus Slot 3 












Flash EEPROM 
(Optional Feature) 


LED and Hex 
Switch 





Hardware 





FORCE COMPUTERS 


Page 3-15 


Hardware SPARC CPU-2CE Technical Reference Manual 


Figure: 3.9 Type 0 Space (Main Memory) (obmem) 
00000000 16 Megabytes 


On-board memory 


01000000 32 Megabytes - 48 Megabytes 


Memory Expansion Board 


08000000 32 MBytes 


SRX Board 
O0A000000 32 Mbytes 


SRX Memory Expansion 
01000000 48 Mbytes 





SRX Memory Expansion 


SSeS 
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3.1.5 Interrupt Map 


The SPARC CPU-2CE interrupt map is upwards compatible with the SPARCstation 2, but includes 
additional interrupts. The following table shows the preliminary interrupt table for the SPARC CPU-2CE. 
Multiple interrupt sources share some of the interrupt levels. 


Table: 3.3 SPARC CPU-2CE Interrupt Priority Levels 


15 
15 SYSFAIL 


is 





NOTE: If VME interrupt level 7 or 6 is needed with VME there is a conflict of the floppy and audio 
ports interrupts. Either the audio or floppy driver must be commented out of the GENERIC.VME and 
GENERIC_SMALL.VME to disable one. Remember to copy the files before modifying them. Search 
the GENERIC.VME and the GENERIC_SMALL. VME files in the .conf directory for audioamd. Use the 
"#" pound symbol at the head of the line to comment out either the audio or fd line. Then rebuild the 
kernel. See the readme file in the .conf directory for further details. 
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3.2 Custom Chips 


The new ASICs are the Cache controller, DRAM controller, DMA controller, and the MMU chip. 
Further details on these ASICs are available in their respective chip specifications. 


3.2.1 Cache+ 


The Cache+ ASIC consolidates the original Cache, Buffer, and the cache tags, all on one 224 pin 
chip. The Cache+/Sunray cpu core will operate at a clock rate between 33 and 40 MHz. The 
SBus will run at one-half the cpu clock rate. In order to balance the system somewhat (so that 
cache miss performance will not be terrible) anew RAM controller provides for 1-word-per-clock 
burst fills. In addition, a micro-TLB eliminates or reduces MMU translation time when the 
segment or page portions of the virtual address do not change. The Cache+ chip does not do 
parity checking; that function is moved to the RAM+ chip. 


3.2.2 RAM+ 


The RAM+ chip is a DRAM controller and datapath chip for SBus systems. It uses 80 nsec 
DRAMS to give burst reads and writes at one word per clock. It does parity generation and 
checking. It has a 2-word write buffer to provide quick response to cache write-through 
operations. The RAM+ has a private RAM Data bus, isolating the DRAM data from SBus data. 
This lowers the load on the SBData lines, in addition to allowing the RAM+ chip to do buffered 
writes while releasing the SBus. 


3.2.3 DMA+ 


The DMA+ chip is an update of the DMA chip, with optimizations to allow full speed SCSI 
operation along with ethemet on a 20 MHz SBus. It has an intemal line buffer and does SBus 
operations one line at a time (where possible) in order to minimize SBus usage. 


3.2.4 MMU+ 


The MMU+ gate array contains clock generation logic, the system parallel port, and the MMU 
datapath/decode logic. It is changed from the MMU chip in its decodes for the iodata bus (since 
the parity control register is no longer on the iodata bus). 


3.2.5 SPARC CPU-2CE CACHE Controller 


The Cache Controller controls the operation of the cache memory subsystem, provides a path to the main 
memory of the SBus, supports a single 64 Kbyte instruction/data cache, and monitors/controls the’ 
operation of the SBus. For the SBus it handles all arbitration, SBus watch functions, and fetching data 
and writing data back to memory. 
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The Cache Controller features: 
Virtual address, direct mapped instruction /data cache controller 
Supports 64 Kbyte write through cache, with 32-byte line size 
Integrates cache tags on-chip (2 K x 21 bits) 
Micro TLB improves performance to main memory or I/O devices 
Controls SBus reads and writes 
Supports three (full master/slave) SBus slots 
Automatically fills cache on cache misses 
Integrates write buffer logic and performs buffered writes that support up to two double words 
Performs cache flush comparisons 
Controls CPU byte packing 
Contains Virtual Address Error Latches 
Maintains copy of context registers 
Contains Bus Error register (both address and data) 
Monitors bus for unacknowledged transfers 
Generates system reset 
Tag support for 16 contexts 


Hardware assisted context, segment, page and virtual flushing 


The Cache Controller functions: 


The cache is organized as 2048 lines 32 bytes each. The cache tags are 21 bits wide and 
integrated into the cache controller chip. 
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Function of Write Through Cache Control 


Lines are only loaded into the cache when the IU accesses (reads) a cachable memory location 
(Read Miss). Data is written into the Cache by the IU only if the location already resides there 
prior to the write. In all cases writes will be sent back to the main memory. Subsequent reads 
to the SBus are blocked until any pending writes are completed. 


The cache design is implemented as a write-through cache to avoid halting the operation of the 
IU while the write to main memory occurs (2-entry cache write buffer has been implemented that 
allows the IU to continue operation) the IU is released early from a write only, if it is a cache hit, 
otherwise, the IU will be held until the write access will be finished. 


eee 
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3.3 SPARC Expansion Connector 


3.3.1 Overview 


SPARCstation-1, SPARCstation-1+, SPARCstation IPC, SPARCstation-2 and FORCE CPU-2CE 
all have an additional expansion connector beyond their SBus slots. These connectors are not 
identical, but do have some commonality between them. These connectors are not part of the 
SBus. They have different timing and loading requirements, and they are not guaranteed to be 
on any future Sun SBus machines. The purpose of this document is simply to allow access to 
these connectors (in the spirit of Openness). But first, this warming: 


The expansion connector described in this document will continue to be supported throughout 
the product lifetimes of the specific machines listed. It will NOT necessarily be supported on 
any future SPARC Boards. 


3.3.1.1 Intent of the Expansion Connector 


The original intent of the SPARC Expansion Connector was for memory expansion without 
performance compromises. To this end, certain assumptions are made about devices which 
respond to the sel* signal on the Expansion Connector (such as support for burst fills). These 
requirements will be detailed below. In addition, these connectors are not identical from machine 
to machine. They were intended for internal use only, with minimal compatibility between them. 


3.3.2 Reconciling the Differences 


As there are some annoying differences between the expansion connector on various systems, this 
section will attempt to address methods of living with all of the flavors available. 


3.3.2.1 Pa26 


SBus address line 26 is not available on the SPARCstation-1 version of this connector. On the 
other hand, it is available on the SBus connector itself for SPARCstation-1's. Pin 46 of SS-1's 
SBus connector is pa26. On all other SPARCstations mentioned in this document, pin 46 of their 
SBus connectors are ground. Since Pin 1 of the expansion connector is ground on SS-1, the same 
functionality (with slightly later timing) can be achieved by OR-ing together pin 46 of the SBus 
connector and pin 1 of the expansion connector, one of the two will always be ground on these 
machines. 


3.3.2.2 Pa25 
SBus address line 25 is only available on SPARCstation-2's expansion connector (although it is 


also available on the SPARCstation-1 SBus connector). There is no way to depend upon pa25 
across all versions of the SBus-based SPARCstations. 
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3.3.2.3 POK 


Power OK is only available on SS-1, SS-1+, and SS-IPC. A better source for reset is the SBus 
reset* signal. The major difference is that reset* is asserted on watchdog and software resets, 
while pok is negated (low) only after (or during) a power failure. 


3.3.2.4 RamclkN 


The ramclk's are intended for a SPARCstation-2 memory controller. Do not put more than one 
CMOS load on either clock. It is vastly preferable that only the SBus clk signal be used. 


3.3.2.5 Ramsel* vs. ramsell* 


Ramsell* is “safe” in that no further decoding need be done; if you see ramsel1* and as* 
asserted, you are selected. On the other hand, ramsel* needs further decoding; you must see 
ramsel* asserted, as* asserted, and pa26 high before selecting yourself. Ignoring pa26 will lead 
to bus conflicts with the on-board memory controllers. The simplest resolution to these 
differences is simply to use pa26 in all cases, and specify your board's address space for software 
purposes as 0xC000000 - OxFFFFFFF (pa26 and pa27 both high). 


Figure: 3.10 Safe Decode Circuit 





3.3.2.6 ParityN vs parcs1*, ramclk1, pa25, and perr* 


In order to work with both types of machines (SS-2's and those requiring parity) your controller 
board must have a mode bit which will call ss2mode. When not in ss2mode, the parityN signals 
must be driven on SBus reads (possibly with the value written on the last write to that address, 
possibly with parity values calculated on the fly with the data). On SBus writes, the parityN 
signals are driven by the cpu board, but are not intended to be used for error detection (although 
they could be). 


When in ss2mode, (and after reset-- until you determine that you are not an SS2) you should not 
drive any of these pins, as you could cause a bus conflict with parcs1*, ramclk1, or pa25. 


The fcode boot prom should be able to determine cpu type from the top byte of the hostid of the 
system. Use this information to decide how to set ss2mode. 
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3.4 SCSI Interface 
3.4.1 SCSI Definition 
The Small Computer System Interface (SCSI) uses the NCR 53C90A controller chip and is augmented 
by the DMA+ chip with a data path of 8 bits. It features full compatibility with SCSI Specification, 
ANSI x3.131/1986. This allows the SPARC CPU-2CE to directly control and access a wide variety of 
mass storage devices such as hard disks, tapes, and CD-ROMs. 
Up to seven external SCSI devices can be connected to the SPARC CPU-2CE. The SCSI bus is buffered 
and terminated so SCSI device connections are simple and straightforward, fully supporting synchronous 
and asynchronous operations. SCSI termination is self sensing. Just plug a terminated device on and 
the board will adjust termination automatically. For versatility and flexibility, the SCSI bus on the 
SPARC CPU-2CE is routed to both the front panel via a 50-pin SCSI-II connector and to the board's P2 
User I/O pins. 
3.4.2 SCSI Performance 
The NCR 53C90 Extended SCSI Processor timing is as follows: 
Synchronous Mode Speed: 

Absolute Maximum; 5.0 MB per second* 

Typical: 2.5 MB per second 
Asynchronous Mode Speed: 

Absolute Maximum: 3.0 MB per second 

Typical: 1.75 MB per second 


* Note: The current maximum transfer rate in synchronous mode when using SUNOS (version 
4.1.1b) is 4.0 Mbytes per second. 
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3.4.3 SCSI Addresses 


The following table lists the physical addresses used to access the SCSI registers for byte loads and stores. 


Table: 3.5 SCSI Register Addresses 











FIFO Flags/Synchronization 
Offset 


OxF080002C Chip (Extended SCSI 
Processor) Configuration-2 


NOTE: Byte accesses must be performed even though the addresses are all fullword-aligned. 


3.4.4 SCSI Interrupt 


The SCSI Interrupt is Level 3. 
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3.4.5 Interface Programming 


Since the SCSI controller uses the DMA controller to perform the actual transfer of data to and from 
memory, the two devices must be programmed together. One possible algorithm is as follows: 


scsi_startO 
{ 
/*start an operation on the SCSI*/ 
lock data pages into contiguous virtual memory; 
DMA _address_register = starting virtual address; 
setup SCSI registers (except for "go"); 
DMA_control_status_register = (EN__DMAIINT_ENI(other bits)); 
start SCSI; 
/*The SCSI will interrupt us when it is done.*/ 
} 


scsi_interrupt0Q 
{ 
/*must drain DMA on a read from disk/write to memory*/ 
if (last operation==READ) { 
DMA_control_status_register=(DRAIN); 
} 


For a detailed description of the SCSI registers, see the NCR 53C90 Data Sheet. 
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3.5 Ethernet Interface 


3.5.1 Ethernet Interface Definition 


The Ethemet controller is the AMD AM7990 LANCE chip. The data is translated for the Ethemet by the 
AM7992 Serial Interface Adapter (SIA). The LANCE connects directly to the DMA, over unique Ethemet 
interface signals. The DMA will provide all necessary buffering and arbitration functions to allow the 
Ethernet chip to access main memory. The DMA Ethernet interface contains a 1 word (32bit) 
pack/unpack register with consistency control logic. Consistency control ensures that all data written by 
the Ethemet chip gets to main memory in a deterministic manner. 


The LANCE uses multiplexed address and data, so the DMA demultiplexes them internally. The address 
supported by the LANCE is 24 bits; as per the SPARCstation specification the upper 8 bits of the 32 bit 
virtual address are driven to OxFF. The LANCE has a 16 bit data path which can accommodate 8 or 16 
bit accesses, by the use of byte masking capabilities. 

3.5.1.1 Ethernet Transmits and Receives 

When it is in transmit mode, the AM7990 LANCE transfers data from the current buffer in LANCE to 
a register called a Silo. The output of the Silo is serialized and then goes to the Serial Interface Adapter 
(AM7992). The output of the Serial Interface Adapter is connected to the Ethemet lines through a 
transformer. 

In the receive mode, the Serial Interface Adapter (AM7992) receives data from the Ethemet cable. It 
transfers the data to the Silo in the LANCE. The LANCE transfers the data from the silo to the correct 
buffer in local memory. 

3.5.1.2 Ethernet Buffer 

The LANCE Controller utilizes up to 128 Kilobytes of memory for buffers. These buffers are allocated 
from the SPARC CPU-2CE’s onboard parity memory. 

3.5.2 Ethernet Performance 


Maximum Transfer Rate: 10 Mbits per second 


Maximum Observed Rate: 7.5 Mbits per second 


3.5.3 Ethernet Interrupt 
Processor Level 5, SBus level 4 


SPARC CPU-2CE can transfer data from the Ethemet into the on-card buffer memory at a maximum 
(theoretical) rate of 10 megabits/sec. 
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3.5.4 Ethernet Addresses 


The Ethernet Controller chip is in SBus slot 0 address space at OxFOC00000. The following table lists 
the address and location of its internal registers: 







Se 










For additional information, see the AMD Am7990 Data Sheet. 


3.5.5 Ethernet Interface Programming 


/* Initializing on-card ethernet chip */ 

*Abstract: Performs |iLance hardware dependent 
variable m 

* initialization for Sun Ethernet 
diagnostic. % 

*Algorithm: Initialize CSR 3 (describe bus 
acquisition * 

:~ procedures to the emulator) .* 

* Initialize global variables and i/o 
data * 

* 


structures. * 
*Routines called: ini_print, ini_read* 
* * 


FI IK KK IK IK IKK IK IK KK KK KK KK KI IK IK IK I IK KR KR IKK IKK KK I IK IK KK IK RK KK IK KK 


*/ 
long le_sys_init (argc, argv) 
int arge ; 
char *argvl[] - 


extern int 


byteswap() ; 


extern short DSPL_ON; 

extern short err_dsp; 

extern char home_adr[6]; 

extern short INTR_ON ; 

extern etraddr myaddr ; 

extern char net_data []; 

extern short int ringsize,bufsize; 

extern int totbuf; 

u_short *rdpp ; /* ptr to reg data port */ 
u_short *rapp i /* ptr to reg adr port */ 
long mrc ; 

long re, 3 

extern int slot; 

int iF 


re = PASS ; 


ss? 
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/* init etherbase_va array */ 
for (i=0; i<= NUM_SLOTS; i++) 
etherbase_va[i] = 0; 


ether.etherbase_size = (int) ROUNDUP (sizeof (LE_BLOCK) , PAGESZ) ; 
etherbase_va[0] = ether.dvma_start ; 


/* Initializing on-card ethernet chip 


id 


mem variables */ 
ether.txbuf_n = ONE << TLENMAX ; 
ether.rxbuf_n = ONE << RLENMAX ; 
ether.txbuf size = 1024 ; /* may need to tweek this */ 
ether.rxbuf_size = 1024 ; /* may need to tweek this */ 


/* set remaining chip/diagnostic ether 


/* map on-card ethernet control block 


& buffers here */ 
/* find the first available block for 
control block */ 
for (ether.etherbase_va=etherbase_va[0],mrc=FAIL; 
PASSED (rc) && FAILED (mrc) ;) 
{ 
if (FAILED (mre = execmap (&ether.etherbase_va, 
&ether.etherdum_pa, 
ether.etherbase_size, 
ether.ether_flags))) 


{ 


ether.etherbase_va += PAGESZ; 


/* increment va by a page */ 


/* will we go beyond dvma space ? */ 

if (((u_long) (ether.etherbase_vatether.etherbase_size) ) 

>= ((u_long) (ether.dvma_start+ether.dvma_size) ) ) 
{ 
re = MEIC 7 
exec_log(ERROR, ALL_DST, 

"le _sys_init (le%d): can not map on-card 

etherbase{%d}@0x%x\n", 


} 

} 

} {*) Fons 

etherbase_va[0] = ether.etherbase_va; 

ether.ethermin_va = ether.etherbase_va + ether.etherbase_size; 


testing_LE,rc,ether.etherbase_va) ; 


rdpp = (u_short *) (ethernet_va[0]) ; /* ptr to reg data port */ 
rapp = (u_short *) (ethernet_va[0] + 2) ;/* ptr to reg adr port */ 
*rapp = 0; /* Select CSR 0 */ 


: /* set the stop bit in csr0 to 
inactivate the lance chip */ 
*rdpp = (*rdpp) | 0x0004; 


for (i=1; i<=slots[0]; i++) 
{ /* Initializing 2nd ethernet chip. */ 
/* map 2nd ethernet control block & 
buffers here */ 
/* find the first available block for 
control block */ 
for (ether.etherbase_va=etherbase_va[i-1]+ether.etherbase_size,mrc=FAIL; 
PASSED(rc) && FAILED (mrc) ;) 
{ 


if (FAILED(mrc = execmap (&ether.etherbase_va, 
&ether.etherdum_pa, 
ether.etherbase size, 
ether.ether_ flags) )) 
/* increment va by a page */ 


nn se aE EEUU EIEEEEI ESSE 
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ether.etherbase_va += PAGESZ; 
/* will we go beyond dvma space ? */ 
if (((u_long) (ether.etherbase_va+tether.etherbase_size) ) 
>= ((u_long) (ether.dvma_starttether.dvma_size)) ) 
{ 


re = mre ; 
exec_log(ERROR, ALL DST, 
"le sys_init (le%d): can not map 2nd 
etherbase{%d}@0x%x\n", 


} 
} 
} /* for */ 
etherbase_va[i] = ether.etherbase_ va; 
ether. ethermin__ va += ether.etherbase size; 
rdpp = (u_short *) (ethernet_va[i]) ;7* ptr to reg data port */ 
rapp = (u_short *) (ethernet_va[i] + 2) ;/* ptr to reg adr port */ 
*rapp = 0; /*Select CSRO */ 
/* set the stop bit in csr0 to 


testing LE,rc,ether.etherbase_va) ; 


inactivate the lance chip */ 
*rdpp = (*rdpp) | 0x0004; /* set stop bit in csr0 */ 


} 7* fox */ 


totbuf = BUFSPC ; 
bufsize = 1024; 
ringsize = TLENMAX; 


/* copy ethernet address from myaddr 
to ) ROME adr */ 


bcopy (myaddr, home_. adr,sizeof(etraddr)) ;/* 1 to 1 copy */ 


net_data[0] = *# net_data[1] = '’\0'; net_data[2] = '"\0'; 
net_data[3] = + net_data[4] = ‘\0’; net_data[5] = "\0'; 
net_data[6] = '\0’; net_data[7] = '\0'; net_data[8] = "\0'; 
net_data[9] = ; met data[10] = 'T’; net ~data[11] = a 


net_data[12] = ’i’; net_data[13] = 's’; net_data[14] = ; 
net_data[15] = ‘i’; net_data[16) = 's’; net_data[17] =’ x 
net_data[18] = ‘a’; net_data[19] = ' "; net_data[20] = ‘t’; 
net_data[21] = ’e’; net_data[22] = ’s’; net _data[23] mith; 
net_data[24] = ’ ’; net_data[25] = 'o’; net_data[26] = '£'; 
net_data[27] = ' '; net_data[28] = ‘t’; net_data[29] = ‘h’; 
net_data[30] = ’e’; net_data[31] = ’ "; net_data[32] = ‘'L’; 
net_data[33] = ’A’; net_data[34] = ‘'N’; net_data[35] = 'C’; 
net_data[36] = 'E’; net_data[37] = ' '; net_data[38] = 'E’; 
net_data[39] = ‘’m’; net_data[40] = ‘u’; net_data[41]) = ‘1°’; 
net_data[42] = ‘a’; net_data[43] = ‘t’; net_data[44] = 'o'; 
net_data[45] = ‘r’; 

err_dsp = SET; /* error display flag */ 
DSPL_ON = 0; /* By default, no debug msgs */ 


INTR_ON = 0 ; 
go_reset(); 


return(rc) ; 
/* le_sys_init */ 


SSS sss 
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3.6 SBus Interface 


3.6.1 Introduction 


Hardware 


The SBus is a non-proprietary I/O expansion bus developed by Sun Microsystems for some new Sun 
systems and card products. The bus resides in type 1 device space. 


3.6.2 SBus Connections 


The SBus connector is located on the component side of the SPARC CPU-2CE card, near the P2 


connector. 













Table: 3.7 SBus Interrupts 





PROCESS | SOURCE 
TRAP TYPE VECTOR 
LEVELS 


Async SBus Error 
Timer 1 | 3 | 
[13 [Audioimermme | a9 | wD 
ae 
| io 
tees 
a ae 







Floppy Disk Conwoter | 27 | 1B 






ee ee | 
a ene ce aa 
GE ‘eel So A 
IRQ 3 
ao a | 
7 [swumer | 0 ] 1 








The column marked "Level" is the Interrupt Level which is encoded to the SPARC main processor, or 
Integer Unit, by the MMU. The source to the MMU is listed under "Source." 
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3.6.3 SBus Slot Addresses 


Address bits PA[27:26] select one of two SBus slots, and bits PA[24:0] are available for addressing 
devices on the SBus card. Bit PA[25] is not used. 


The following table shows how bits PA[27:26] select the SBus slots. 


Table: 3.8 SBus Slot Addresses | 
PA[27:26] fst sd Address Range | 


jor sus stot 04000000 to OXFSFFFFFF 
SBus slot 2 













SBus slot 0 and 3 are not physical slots; they are occupied by devices residing on the SPARC CPU-2CE 
card. 


SBus slot 1 and 2 on the SPARC CPU-2CE are physical slots, where cards such as the SBus video cards 
can be utilized. 


The SBus device addresses are described in the following sections. 


es 
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3.6.4 SBus Slot 0 Devices 


The SBus Slot 0 devices are physically on the CPU card. SBus slot 0 is in type 1 space at a base address 
of 0xF0000000. The base address contains the card ID number, DMA registers, SCSI registers, and 
Ethernet registers. 


Table: 3.9 SBus Slot 0 Addresses 
Description 
Card ID (OxFE810101) 


Control/Status 
Byte Count 
Diagnostics 






| 


























Transfer Count Register 
FIFO Register 
Command Register 
Status Register 
Select/Reselect Bus ID Register 
Sequence Step 

Synchronous Transfer Period Register 
FIFO Flags Register 

Synchronous Offset Register 
Configuration Register 

Clock Conversion Register 

Test Register 


OxFOC00000 Ethernet Registers: 


Data Port 
Address Port 


NOTE: The slot 0 space from 0xF2000000 to OxF3FFFFFF is not used. 









3.6.4.1 Card ID 


The card ID (data OxFE810101 at location OxFO000000) is a line of 
Forth code that identifies the card in SBus slot 0 to the 
operating system (in this case, the CPU card identifies itself). 


ae eee 
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3.6.4.2 DMA Registers 


The DMA register space contains four registers, addressed by fullword loads and stores. 


oxroooG 


0xF040000C DMA Diagnostic Register 
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DMA Control/Status Register 
The DMA control/status register has the following format: 


D[31:27]- DEV_ID 
These read-only bits contain the data 0x0B1000. They identify the Ethernet device type. 


D[27:15] 
These bits are unused; they read back as 0’s. 


D14- TC 
This read-only bit indicates the that the byte counter has expired (decremented to 0). 


D13- EN_CNT 
This read/write bit enables the DMA byte count register. 


D[12:11]- BYTE_ADDR 
These two read-only bits indicate the next byte number to be accessed. 


D10- REQ_PEND 
This read-only bit is set when the DMA interface is active. Note that RESET and FLUSH must 
not be asserted when this bit is active. 


D9- EN_DMA 
This read/write bit is set to enable DMA activity and reset to disable it. 


D8- WRITE 
This read/write bit is set for DMA from memory to device (write) and reset for DMA from device 
to memory (read). 


D7- RESET 
Setting this read/write bit causes a hardware reset. ERR_PEND, PACK_CNT, INT_EN, FLUSH, 
DRAIN, WRITE, EN_DMA, REQ PEND, EN_CNT, and TC are all set to zero. RESET remains 
set, and must be reset to resume operation. 


D6- DRAIN 
Setting this read/write bit forces remaining pack register bytes to be drained to memory. It resets 
itself. 


DS5- FLUSH . 
This write-only bit forces PACK_CNT and ERR_PEND to zero. It always reads as zero. 


D4- INT_EN 
This read/write bit enables interrupts when it is set. 


D[3:2]- PACK CNT 
This read only field provides the number of bytes in the pack register. 


D1- ERR_PEND 
This read-only bit is set when a memory exception occurs, and is reset by setting FLUSH. DMA 
activity stops until it is reset. 


ee eee UE EEE EEE SEIN RE EEENEEEEEISEERERE Sn 
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DO- INT_PEND 

This read-only bit is set when TC=1, or when an extemal device raises an interrupt. 
DMA Address Register 
The DMA address register is located at address 0xF0400004. It holds the virtual address of the DMA 
transfer. Initially, it should be loaded with the virtual address where the DMA will start. As the DMA 
proceeds, both the DMA byte count register and bits [23:0] of the DMA address register are decremented. 
Bits [31:24] of the DMA address register indicate which 16-megabyte portion of virtual memory is 
accessed. These bits are latched; they do not change as the DMA proceeds. 
DMA Byte Count Register 
When the EN_CNT bit in the DMA control/status register is set, bits [23:0] of this register keep a count 
of the number of bytes transferred by the DMA circuits. It should be loaded with the total number of 
bytes to be transferred; it decrements towards zero as the bytes are transferred. When it reaches zero, it 
sets TC and INT_PEND in the DMA status/control register. 
Note that bits [31:24] are hardwired to zero. 
DMA Diagnostic Register 


This register is not implemented at this time. 


3.6.5 SBus Slot 1 Devices and Slot 2 Devices 


Any device plugged into an actual SBus connector on the CPU card is an SBus device. 

As of the print date of this manual, the SPARC CPU-2CE supports two video cards, color and 
monochrome, that can be plugged into the SBus connector on the CPU card. These cards are 
interchangeable at the card level, but require different cables and monitors. The two cards have different 
registers. For specific information on these cards, please refer to The SBus Color & Monochrome Video 
Cards User’s Manual. 

For all other SBus cards, refer to the technical documentation and manuals provided with the card. 


The Sbus supports all SBus devices that Sun’s SPARCstation 2 supports. 


3.6.5.1 SPARC Assembly Language Example 


/* 
* sbus.s 
* 
#define sbud_id 0x00010000/* sbus ID virtual address 
* 
#define sbus_phy 0x£0000000/* sbus ID physical address 
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*/ 
#define TYPE1_ATTRIBUTES 0xd4000000/* valid, writable, don’t 
cache */ 


.seg "text" 
-global Sbus_id 


! Read SBus slot 0 card ID register 


Sbus_id: 
save %sp, -MINFRAME,%sp! preserve calling indow 
set sbus_id, %o0 ! Virtual address to be mapped. 
set TYPE] ATTRIBUTES, %02 ! Page table entry 
attributes. 
set sbus_phy, %o3 ! Physical address to be mapped. 
call map memory ! Map in specified block of memory. 
mov 00, %ol ! Upper virtual address to be mapped. 
set sbus_virt, %15 ! Address of SBus register. 
ld [%00],%14 { Read Card ID status 
nop 
ret 
restore 
/* 
* PMAP .S 
* 
#define SEGINCR 0x40000/* offset between adjacent 
segments */ 
#define SGSHIFT 18/* LOG2(NBSG) */ 
#define ASI_SM 0x3/*segment map */ 
> aad PAGINCR 0x2000/* offset between adjacent pages 
* 
#define PGSHIFT 13/* LOG2(NBPG) */ 
#define ASI_PM 0x4/* page map */ 
.seg "text" 
‘ -global _pmap_memory 
* 
* Synopsis: status=pmap_memory(low_va, hi_va, attributes, low_pa); 
* status : (int) don’t care 
* low_va ($10): (unsigned long) initial virtual 
address 
* hi_va (il): (unsigned long) final virtual 
address 
* attributes (%1i2) : (unsigned long) page table entry 
attributes 
* low_pa (%1i3): (unsigned long) initial 


physical address 
* 


* Function "pmap_memory" (physical map memory) linearly maps the range of 
* virtual addresses specified by ‘’low_va’ and ‘hi_va’, beginning at physical 
* address ‘low_pa’, with page table entry attributes ‘attributes’. 


%/ 
_pmap_memory: 
save %sp, -MINFRAME, tsp 
/* 
oo in segment table entries for a linear mapping of main memory. 
* 
set SEGINCR, %13 ! Adjacent segment table entry offset. 
sub $13, Ox1, %14 ! Mask for segment table addressing. 
andn %i0, %14, %12 ! Adjust initial virtual address. 
3: srl %12, SGSHIFT, %10 ! Segment table entry (pmeg number). 
dd %10, [%12]ASI_SM ! Set segment table entry. 
add $12, %13) ‘12 ! Increment address by one segment. 
cmp $12, %1i1 ! If current virtual address is not 
bgt 4f 
nop 


renee reer ——— 
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bleu 3b ! greater than the final virtual 
nop ! address, continue. 
4: 
* : 
* Fill in page table entries for a linear mapping of main memory. 
*/ 
set PAGINCR, %13 ! Adjacent page table entry offset. 
sub %13, Oxl, %14 ! Mask for page table addressing. 
andn %i0, %14, %12 ! Adjust initial virtual address. 
/* 
* Generate the initial page table entry. 
*/ 
andn $i3, %14, %11 ! Adjust initial physical address. 
S38 srl $11, PGSHIFT, %10 ! Page number of page table entry. 
or %10, %i2, %10 ! Combine attributes and page number. 
sta %10, [%12]ASI_PM ! Set page table entry. 
add $11, %13, %11 ! Increment physical address by a 
page. 
add %12, %13, %12 ! Increment virtual address by a page. 
cmp $12, %il ! If current virtual address is not 
bgt 6f 
nop 
bleu 5b ! greater than the final virtual 
nop ! address, continue. 
6: 
/* 
* Mapping completed. 
By 
ret 
restore 


-_—_--_-_-eerrvwmxmx>-:.n nm nm a 
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3.6.5.2 Forth Example 


£000.0000 constant SBUS-SLOTO \ physical address 

0001.0000 constant SBUS-ID \ virtual address 

SBUS-SLOTO obio SBUS-ID map-page \ map into typel (on-card I/O) space 
SBUS-ID 1@ . \ fetch and display sbus-id 


NOTE: SBus slot 0 contains the DMA, Ethernet, and SCSI chips. Slot 1 & 2 contains SBus cards. 


3.6.5.3 C/SunOS Example 
/* 


* caddr_t map_SBus_address(u_int p_addr, u_int num_pages) 
* 

* Inputs: Physical address and the # of pages to map. 

* Returns: Virtual address of the mapped page(s). 

* 


caddr_t map_SBus_address(p_addr, num_pages) 


oe ar p_addr; /* physical address on the SBus to map 
* 
u_int num_pages; /* # of pages to allocate/map */ 
{ 
long v_pgnum; 
u_int v_addr; 
u_int offset; 
u_int pg_tbl_ent; 
/* 


* Save the offset from the page boundary so that 
* we can apply it to the virtual address once the 
* page is mapped in. 

* 


offset = p_addr & MMU_PAGEOFFSET; 
/* 
* Create a page table entry that maps the physical address 
* “"p addr" into SBus space. 
*/ 


‘ pg_tbl_ent = PGT_OBIO | PG_NC | btop(p_addr); 

* 

* Allocate virtual pages that we can use from the 
* kernel map of available virtual addresses. 


= / 
v_pgnum = rmalloc(kernelmap, (long) btoc(num_pages) ); 
if (v_pgnum == 0) /* no addresses available from kernelmap */ 
j return (caddr_t)0; 
* 
* Convert the virtual page # to a virtual address 
x 
; v_addr = (u_int) kmxtob(v_pgnum) ; 
* 


aaa the physical address into our allocated virtual address. 
* 


segkmem_mapin(&kseg, v_addr, num_pages, PROT_READ | PROT_WRITE, 
pg_tbl_ent, 0); 
/* 
* Return to the caller of this function the virtual address of 
* the mapped SBus physical address. 
=f 
return (caddr_t) (v_addr | offset); 
} /* end of map_SBus_address */ 


nd 
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3.7 RAM+ 


3.7.1 FEATURES 


3.7.2 PIN DESCRIPTION 


3.7.2.1 
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¢ Provides all DRAM timing and refresh cycles. 


¢ Controls 64 Mbytes. 


e Generates and checks byte-wide (or word-wide?) parity. 


° Supports 32-byte and 8-byte SBus sizes. 


The RAM+ chip is built in a 196-pin plastic flat pack. It has X outputs, Y bidirectional pins, Z 
inputs, A VCC pins, and B Grounds. 


Sbus Interface 


clk 


sb_d[31:0] 


sb_pa[27:0] 


sb_siz[2:0] 


sb_rd 


sb_ack32_ 


sb_merr_ 


sb_as_ 


selram_ 


(TLCHT) System clock. This signal runs at up to 20 MHz with a 50% 
duty cycle. (Perhaps: for clockrates greater than 20 MHz, the 
configuration register must be set to two-clocks-per-word mode.) 


(BD8) Sbus data. On read cycles, this data is guaranteed valid ~i. ihe 
clock following an "ack." 


(TLCHT) SBus physical address. It is guaranteed to be valid before the 
Clock edge in which sb_as_ is sampled low. 


(TLCHT) SBus size control signals. The RAM+ chip supports an exten- 
sion of the normal SBus size codes for 8-byte and 32-byte bursts. 


(TLCHT) SBus read control signal. This signal is asserted (high) for 
read cycles and negated (low) for write cycles. 


(BT4) SBus acknowledge for 32-bit word size. Tri-state output. It is 
asserted (low) for one clock for each word transferred. 


(BT4) SBus Memory Error. Asserted after data to report parity error. 


(TLCHT) SBus address strobe. This signal is asserted (low) by the 
system controller for the duration of an SBus cycle. 


(TLCHT) Ram select input. This signal is asserted (low) to indicate that 
a DRAM access is taking place. It is asynchronous when sb_as_ is not 
asserted. (It only guarantees a setup to a clock edge when as_ is also 
seen asserted.) As long as parity is internally enabled, all accesses are 
checked. There is no "par_en_" signal on the RAM+ chip. 
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par_cs_ (TLCHT) Parity register select input. (There is a problem currently in 
that the MMU chip asserts ioden_ during par_cs_ and pio_sel_ 
cycles.) 

totals: inputs: 36, outputs: 2 , bidirects: 32. 


3.7.2.2 DRAM Interface 


ram_d[31:0] (BD4) DRAM data bus. Driven during write cycles, latched during reads 
on the rising edge of cas_. Each signal drives 4 pins. 


ma[10:0] (BT4) Multiplexed DRAM address bus. These 11 address lines contain 
the addresses to be used by the DRAM at the next falling edge of ras_ 
or cas_. They will be buffered externally. DRAMs expect O nsec setup 
time and 10 nsec hold time wrt ras_ and cas_. 


we_ (BT4) Write Enable outputs to all DRAM banks. Assumed to be 
extemally buffered.. 

ras [15:0] (BT8) Row Address Strobe outputs to DRAM banks, one for each byte. 
Each signal drives 9 pin. 

cas_[15:0] (BD8) Column Address Strobe outputs to DRAM banks, one for each 


byte. Each signal drives 9 pins. These signals use bidirectional pads 
because the cas_ signal is read back in to provide the clock for the read 
data register. 

p[3:0) (BD8) Parity input/output. Each signal drives 4 pins. 


totals: 
inputs: 0 , outputs 28 , bidirects: 52. 


3.7.2.3 Power/Ground 
totals: 41 VCC: x , Ground: 41 - x. 
3.7.2.4 LSI Logic Buffer Naming Conventions 


Input pads are generally TLCHT's. Outputs are generally BTx's where x is the number of 
milliamps of drive capacity. BDz’s are bidirectional pads with x milliamps of drive. 


aaa E EEE EEE 
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Table: 3.11 Address Ranges 





Address Range/Bank Pin Usage 
0000000 - 3FFFFFF / 0 DRAM (parity-protected) 
8000000 - BFFFFFF / 1 ‘ 

4000000 - 7FFFFFF / 0 Video Registers 


¢ RAM Banks may be made up of 1 
Mbit or 4 Mbit DRAMs, providing up to 
64 Mbytes of memory. 


¢ When a bank is filled with 1 Mbit 
DRAMs, the memory contents are 
"shadowed" four times. 


¢ If a bank is not populated with DRAM, 
the RAM+ chip still responds with an 
ack32_ to all requests. No errors (other 
than possible parity errors) are returned. 


¢ The base address of the Frame Buffer 
is programmable. 





3.7.3 SBus INTERFACE 


3.7.3.1 DRAM Access 


All DRAM timing diagrams assume no contention for the DRAM. If the SBus request is lower 
priority than another requestor, waitstates will be added. Writes will only be delayed if the Write 
Buffer is full. DRAM and Video Register accesses are initiated by seeing both sb_as_ and 
ramsel_ asserted on the rising edge of an sb_clk. In the following diagrams, the logical AND 
of sb_as_ and ramsel_ is shown as sel_. 


EEE 
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¢ Word Read 
RAM+ reads are done in the "fast mode" of the RAM chip. sb_rd is high: 


Figure: 3.11 Word Read 


sb_clk 


sel 


sb_a 
sb_ack32_ 


sb_d 


casx_ 


ma 





The following diagram shows the capture of data from the ram data bus to the sb data bus: 


Figure: 3.12 Word Read 2 





cas_ from 
state machine 


ram_d ae ie al sb_d 
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* Word Write - Buffered 
Writes go directly into the write buffer and release the bus. sb_rd is low: 


Figure: 3.13 Word Write 


' = 2 3 

AH 
ie ha 

sa Sa ore kate ne eee 
tbs eee a 
ee 

Ty 
= 122 
ram_d ph i a 
- ai 
~ ry 


ma 

The data on the sb_d bus is sampled on the same clock as sb_as_ and ramsel_. Data on the 
ram_d bus is driven on the falling edge of sb_clk. (It is possible that this cycle will need to be 
extended one clock such that the ram_d bus is driven on the falling edge of cycle 2, rather than 
cycle 1. This would not slow down the ack32_ response, however. (This would be because of 


writebuffer fallthrough time, and also because the burst writes must wait until cycle 2 for their 
first cas, as well.) 


ssn 
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e Burst Read 


Only an 8-byte Burst Read is shown. For a 16-byte burst, add two more clocks. For a 32-byte 
burst, add 6 more clocks. sb_rd is high: 


Figure: 3.14 Burst Read 


sb_clk d oh d 
_ Babak 
ptt 
sb_a (CBRiksann 


j 
H 
sb_ack32_ 
C | D ata Data 


Pwtabcocccnccadeccoccccecccccsesonscssssssess! 


sb_d 


ram_d 


. x a 


ee Se © anna 


ecccceccccccccccececfocecococcececesecces: 


” 
a 
3 
4 
t 


SBus addresses will not change during a burst access. The ma address lines must increment 
themselves, wrapping around mod(8) for 8-byte transfers, mod(16) for 16-bytes transfers, and 
mod(32) for 32-byte transfers. (In reality, no 8-byte transfer will ever take place except on a 
longword boundary. 16 and 32-byte transfers may take place on any word boundary.) 


ee 
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* Burst Write 
Only an 8-byte Burst Write is shown, and the write buffer is not full. sb_rd is low: 


Figure: 3.15 Burst Write 


sb_clk { : d : 
MER 
sel_ H 
Reais | 
sb_a ‘SAGE TREE Ue | 
; H H 
sb_ack32_ P | Bi idima 
sb_d Cf patao _Datat > 
aad aa ois 
{ at | ; i 
. ini 
rasx_ | 
hadi ie 
ma xx K_ Row! X| Cold X co X {xx | 
ram_we_ i 
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3.7.3.2 Address Mapping 
The row and column address bits for the RAM+ chip are compatible with the RAM chip in its 
4Mbit mode. No 1Mbit mode is available. 


sb_a ma 
a0 byte 
al byte 
a2 col0 
a3 coll 
a4 col2 
a5 col3 
a6 col4 
a7 col5 
a8 col6 
a9 col7 
al0 colg 
all col9 
al2 row0 
al3 rowl 
al4 row2 
al5 row3 
al6 row4 
al7 row5 
al8 row6 
al9 row7 
a20 row8 
a21 row9 
a22 row10 
a23 coll0 
a24 setO 
a25 setl 
a26 ram_/reg 
a27 bank 


Byte[1:0] specifies which byte within the word will be accessed. 

Set[1:0] specifies which of the four ras/cas sets will be accessed. 

Ram_/reg is low to access DRAM, high to access video registers. 
Bank is the bank strapping pin. 


2 EEE ESEEIEE= 
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3.7.4 DETAILED TIMING 
3.7.4.1 DRAM Timing 
The ram+ chip is designed to work with 80 nsec 1Mb and 4Mb fast page mode DRAMs at 20 


MHz SBus clock, and 100 nsec DRAMs at 16.67 MHz. The crossover point between the two 
DRAMs is thd. 


DRAM Errors 


When memory parity errors are reported (either as a result of processor or DVMA activity) a 
physical address is reported, along with the contents of the memory error register. The following 
table maps physical addresses and error register bits to SIMM locations. 


Table: 3.12 DRAM maps physical addresses to SIMM Locations 


Address Base Error Register Bits------------------------------------------ 
8 (D[7:0]) 4 (D[15:8])2 (D[23:16])1 (D[31:24]) 
0x0 U0322 U0307U0309U0311 
0x 1000000 U0321 U0308U0310U0312 
0x2000000 U0320 U0315U0314U0313 
0x3000000 U0316 U0317U0318U0319 
DRAM 


For further details on the DRAM subsystem of, see the RAM+ Controller Specification. 


eee > OO erehahr 
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3.8 The MMU+ 
3.8.1 Features 
¢ Provides data paths to Sun-4 SRAM MMU 
e Updates MMU statistics word 
¢ Provides decodes and timing strobes for Type-1 devices 
¢ Prioritizes 15 levels of interrupts 
e 4-bit context register allows 16 contexts 
¢ Two counters generate high-resolution periodic interrupts 
¢ Crystal oscillator for serial ports 
¢ Assumes 20 nsec page and segment RAMS: one clock write cycles. 
¢ Supports up to 256 PMEGS 
Figure: 3.16 Segment Map & Page Map 


sb_a[29: 18] 
sb_a{17:12] 








iod[7:0) <———> 


pio[7:0] 


sb_pal27:12] 






Decodes 
irq 
iu_irl{3:0) 
iu_clk 
clk fpu_clk 
(80Mhz) Pei ae > scrial_clk 
ram_clk 
sbus_clk 
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3.8.2 Pin Description 





3.8.2.1 SBus Interface 

sb_clk (DRVT4) System clock. This signal runs at up to 20 MHz with a 50% 
duty cycle. 

sb_a[3:0] (TLCHT) Low-order sbus address lines used for internal byte and register 
selects. 

sb_rd (TLCHT) High during sbus read cycles, low during write cycles. 

sb_as_ (TLCHT) SBus Address Strobe. Low during valid SBus cycles. 

sb_reset_ (TLCHT) Low to reset SBus devices. 

sb_ack8_ (BT4) SBus 8-bit acknowledge. Used to terminate an SBus cycle when 
the addressed device is 8 bits wide. 

iod[7:0] (BD4) 8-bit buffered extension of SBus for on-board data. Used to 
access on-chip registers and MMU RAMs. 

pio[7:0] (BD4TOD) Pseudo-bidirectional parrel port pins. to use as inputs, the 
controlling register should be programmed with 1’s. To use as out puts, 
the pin should have a pullup resistor added externally. 

ctl[2:0] (TLCHT) Encoded control space selects from Cache+ chip. Private 
signal from cache chip. 

devspc_ (TLCHT) Low for device space accesses, High for control space accesses. 
Private signal from cache chip. 

user_ (TLCHT) Low for user space accesses, high for supervisor space 
accesses. 

sb_bg[3:0] (TLCHT) Any one of these signals is Low during DVMA accesses. 
Forces CID output to zero. 

devspc_ (TLCHT) Low for device space accesses, High for control space accesses. 
Private signal from cache chip. 

user_ (TLCHT) Low for User Space accesses, High for Supervisor Space 
accesses. Private signal from cache chip. 

sb_bg[3:0]_ 
(TLCHT) Any one of these signals is Low during DVMA accesses. 
Forces CID output to zero. 

3.8.2.2 MMU Interface 

cid[3:0] (BT2) Context ID to Segment Map RAMs. 

pmeg[7:0] (BD4TD) Page Map Entry Group. Data bits to/from Segment Map 
RAMs; used for programming Segment Map. 

pa[27:12]) (BD4T) SBus Physical Address bits to/from Page Map RAMs. Used for 
programming Page Map and as inputs for decodes. 

mmul[v,w,s,x] (BD4T) MMU Valid, Write-allowed, Supervisor-only, don't-cache bits 
to/from Page Map RAMs. Used to program Page Map and as inputs for 
permission checks. 
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The MMU+ is built in a 160-pin plastic flat pack. It has 40 X outputs, 48 Y bidirectional pins, 
36 Z inputs, 17 A VCC pins, and 19 B grounds. 
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3.8.2.3 


mmu_typ[1:0] 


mmu[a,m] 


sm_wr_ 
pm_wr[2:0]_ 
Decodes 
ramsel_[1.0] 


kbm_rd_ 


kbm_wr_ 


scc_rd_ 


scc_Wr 


tod_cs_ 


par_cs_ [1.0] 


eprom_rd_ 
fd_rd_ 
rd_wr_ 
iosel_ 
sb_sel[3:0]_ 


iod_en_ 
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(BD4T) MMU Type bits to/from Page Map RAMs. Used to program 
Page Map and as inputs for decodes. The type bits are essentially 
extensions of the physical address output where Type 0 is on-board RAM 
and Typel is IO and SBus. Types 2 and 3 are not used on this newer 
design, but are supported for VME-based machines. 

(BD4T) MMU Accessed and Modified bits to/from Page Map RAMs. 
Used to program Page Map and updated during all device-space accesses. 
Any access to a page marks the a bit to one, while any successful write 
to a page marks the m bit to one. 

(BT4) Segment Map Write Enable. 


(BT4) Page Map Write Enables. 


(BT2) DRAM select. Asynchronous Decode 


(BT2) Read Strobe for 85C30. Asserted during reads and during reset. 
Synchronization hold-off is guaranteed. 


(BT2) Write Strobe for 85C30. Asserted during writes and during reset. 
Synchronization hold-off is guaranteed. 


(BT2) Read Strobe for 85C30. Asserted during reads and during reset. 
Synchronization hold-off is guaranteed. 


(BT2) Write Strobe for 85C30. Asserted during writes and during reset. 
Synchronization hold-off is guaranteed. 


(BT2) Chip-select signal (active low) for MK48T08 TOD/NVRAM chip. 


(BT2) Chip-select signal (active low) for parity control/status register in 
RAM2 chip 


(BT2) Read/Output Enable for EPROM accesses. 
(BT2) Active-low floppy controller read strobe. 
(BT2) Active-low floppy controller write strobe. 
(BT2) Select for Type 1 device 

(BT2) SBus selects Asynchronous decodes. 


(BT2) iod bus enable. Asserted low whenever an access takes place on 
the iod bus. 
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sb_merr_ 


irg(13:11,9:1]_ 


iu_irl[3:0) 


3.8.2.4 Miscellaneous 
const_clk 
XSO/XSI 
sclk4 


pio[7:0) 


od_ 


para 
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(TLCHTN) sbus memory error/async error signal. Used to generate 
non-maskable interrupt when an async error occurs. Edge-sensitive. 
External Pullup Required. 

(SCHMITCN) Interrupt request inputs. External Pullup Required. 
(BT2) Encoded Interrupt Requests to Integer Unit. Positive-true; zero 


indicates no interrupts pending, OxF indicates a level-15 (non-maskable) 
interrupt is pending. 


(TLCHT) x-MHz clock used for counter-timers. 

Oscillator input/output pins for 19.66 MHz xtal. 

(BT2) Serial port clock; XSI divided by four. 

(BD4TOD) Pseudo-bidirectional parallel port pins. To use as inputs, the 
controlling register should be programmed with 1's. To use as outputs, 
the pin should have a pullup resistor added externally. 

(TLCHTU) 


(BT1) Parametric output for testing only. 


32 in, 32 out, 48 bidirect... 112 total. 


3.8.3 Clock Generation 


3.8.3.1 General Description 


The MMU+ chip generates all system level clocks required for the IU, FPU, SBus and Ram+ controller. 
The input clock frequency is four times the desired Sbus frequency. The clock logic will generate a divide 
by two output for the IU and FPU. The clock is further divided (by four with respect to the input ) to 
provide the Sbus and ram controller clocks. While the Sbus clocks are 50-50 duty cycle, the ram 
controller clocks are 25-75 and 75-25. 


CLK4 


oJ LSS UT er i ae 


TU_CLK | | | | f | | 
FPU_CLK 
sB_CLK(1:0) __| | | a 


RAM_CLK[0) | | | 
RAM_CLK{[1)} | | 
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3.8.3.2 Constant Clock 


A constant clock input is used to provide a 100nS clock to the counter-timers. Since the main clock and 
SBus clock frequencies are subject to change, this input is required. 


3.8.3.3 Serial Clock 


The MMU+ chip has a serial clock oscillator circuit used for generation of a 4.91 Mhz, 50-50 duty cycle 
clock. This clock is used by the 85C30 serial chips. The primary frequency of the crystal is 19.66Mhz. 


3.8.4 Decodes 
3.8.4.1 Control Space 
¢ CTL mappings 


The devspc_ signal from the cache+ chip chooses between device space and control space 
accesses. Device space accesses are accessed with physical addresses provided by the MMU 
RAMs, while control space accesses are identified by virtual addresses (decoded from the IU by 
the cache+ chip onto the ctl[m] lines). When devspc_ is high, the ctl lines have the following 
meaning: 


Table: 3.13 CTL mappings 


et [Deve 
[0 [cer mento in| 
[1 [Reser for VME Ack | 
[2 [Comex Reger 
Ps [scones 
Ts [semen Map 
ici [7 iain 
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e Context Register Access 
Writing to or reading from ASI 2, VAdr 0x30000000 causes the cache+ chip to decode for context 
register accesses. The MMU+ chip will reply with an sb_ack8_. Only byte writes or reads 
should be done. Only the least significant four bits of the byte are used as a context register. 
Writes to this address will go to both copies of the context register: in the MMU+ chip (and to 
the MMU SRAMs) and in the cache+ chip (to be used for cache tag comparisons). Reads from 
this location will come from the MMU+ chip, while reads from ASI 2, VAdr 0x30000001 will 
get data from the cache+ chip. This difference in read behavior is for diagnostic purposes only. 


All internal register accesses use the iod[7:0] bus to transfer data. This bus is simply a buffered 
version of sb_d[31:24]. It is enabled with ioden_ low. 


An internal register cycle is shown below: 


Figure: 3.17 Internal Register Cycle 


An internal register cycle is shown below: 


intemal Register 
Access Cycles 


Read Cycle 


Write Cycle 





¢ SCC Bypass 
Writing to or reading from ASI 2, VAdr OxFO000000 will bypass the MMU and provide access 
to the SCC. See SCC/Keyboard-Mouse accesses for further timing details. ctl[2:0] = 0x4 for 
these accesses. 


¢ EPROM Bypass 


Supervisor Instruction accesses made while the system is in boot state will cause the cache+ chip 
to operate in control space with ctl[2:0] = 0x7. These cycles will be forced to EPROM accesses 
on reads, and no device will be selected on writes. 
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e Segment Map Access 
Writing to or reading from ASI 3 will access the segment map RAM(s). The location accessed 
is specified by the combination of the current context register value and virtual address lines 
sb_a[29:18]. 


The cache+ chip enforces the restriction that the top three address lines, a[31:29] must either 
all be ones or all be zeros. 


The number of contexts supported (8 or 16) is system-dependent. The mmut+ chip supports up 
to 16 contexts. 


Segment Map write cycles cause the iod[7:0] value to be driven onto the pmeg[7:0] lines. The 
output of the Page Map is ignored for this (and all control space) cycle. 


The sb_a[29:18] and ctxt[3:0] signals are valid by the clock cycle in which sb_as_ is asserted: 


Figure: 3.18 Clock Cycle 


Segment Map 
Access Cycles 


Read Cycle 
(sm_wr_ high) 


Write Cycle 





The sm_wr_ signal is asserted for one clock. The first half-clock is used to allow the segment ram to get 
off the pmeg databus. During the second half-clock the mmu drives the value from the iodata bus onto 
the pmeg bus. The mmu continues to drive this data for the half-clock after sm_wr_ is negated to allow 
for hold time. During this clock, both the segment map RAM and the mmu+ will be driving the same 
data onto the pmeg bus. The sb_a[29:18] lines must not change in the clock following sb_as_ negation 
on segment map access cycles. 


Critical Path: ioden_ to iod[7:0] valid to data out on pmeg[7:0]. Must all happen 40 nsec after 
sb_clk rising edge. 


Only byte accesses, with ls address bits zero, should be made to the Segment Map. 
me 
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e Page Map Access 


Page map access is extended by 4 bits on the CPU-2CE for VME only. Writing to or reading 
from ASI 4 will access the Page Map RAMs. The location accessed is selected by the pmeg 
value (selected by the current context and sb_a[29:18]) concatenated with sb_a[17:12]. Timing 
is identical to the Segment Map cycles, except that for word accesses, four cycles will be done 
(because the mmu+ will respond with sb_ack8_). The page map value is defined as follows: 


Page Type Entry 





¢ Page Type Bits 


Bits 31 through 16 of the page map entry provide the following information about the page: 
27 and 26 Type bits, which select device space access as shown in the following table. 


Table: 3.14 Page Type Bit Definitions 


Viet ct | Pd | 
fo fo Min memory (ype | 
fot fv spacey 
fof ve is Pon ype 2) 

i | ve 32 Pon (ype 3) 









sn 
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3.8.4.2 Device Space 





Table: 3.15 Device Space 















| OOXXXXXX | Ramsel [0] (on-board DRAM) 

to 

| O7TXXXXXX 

| O8XXXXXX | Ramsel [1] (off-board DRAM) 
5 

OFXXXXXX 

Loa FOXOOXXX | Keyboard/Mouse 

1 | x00 

reaeel F2X0X TOD, NVRAM 






Counters 

Parity Control/Status [0] 
Parity Control/Status [1] 
Interrupt Control 


F3X00 
XX 


oO 


= 


a[Elglglz 
8 S|isis 
Oe 


Floppy 
Audio 


F7400XXX | Aux I/O 
SBS¢l Zero 






aig 1 
~*~ 

: 

9 


iE 


a 
: 


XXX 
FCXXXXXX | SBSel Two 


FLASH (Optional Feature) 
LED’s and Hex Switch 











SBus Select Zero is for on-board DMA on the CPU-2CE. Both Floppy and Audio use the fd_rd_ 
and fd_wr_ signals. The use of sb_a[12] to distinguish between the two devices is done at the 
board level, not in the mmu+ chip. 


For Interrupt and Counter accesses, see the details in following chapters. 
Devspc_ is assumed low in the following diagrams. 
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¢ SBus or DRAM Access 
SBus and DRAM decodes are different from any other mmu+ decode. In these cases, the mmu+ 
does not provide any sbus acknowledge (the sbus device or ram controller is expected to do that) 
and the select signal is totally asynchronous. The sbus device or ram controller must look at both 
its select signal and sb_as_ in order to decode itself. 
The following diagram shows an SBus or DRAM access: 


Figure: 3.19 SBus or DRAM Access 


sb_clk 
sb_as_ 
sb_pa 
ramsel_[x] 


devspc_ 


Sb_ack{8,32}_ is not shown; it is generated by the slave device. The sb_pa lines also include 
the mmu permissions and statistics bits. The ramsel_ output could as easily be an sb_seln_ 
signal. See the note on statistics updates regarding how ) quickly the physical address may change 
to guarantee correct operation on statistics update cycles. 


EEE EEE 
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« TOD, EPROM, Floppy Access 
The 48T08, EPROM, and Floppy Controller/Audio chips have identical timings. 
The EPROM and 48T08 are assumed to have a 200 nsec access time. 


Figure: 3.20 Scan EPROM Access 


sb_clk 
sb_as_ 
sb_ack8_ 


ioden_ 
sb_rd 





Figure: 3.21 2nd EPROM Access 


sb_clk 
sb_as_ 
sb_ack8_ 


ioden_ 
sb_rd 





TOD, Floppy Write Cycle 


Note that the wr_ strobe (or cs_, in the case of the TOD chip) is asserted before the data is valid. 
The iod bus makes setup to the trailing edge of the wr_ strobe. In addition, the minimum wr_ 
low time for the Am79C30 is 200 nsec. This is guaranteed by the fact that LSI's process goes 
low faster than high.Writes to the EPROM will retum an sb_ack8_ but will not enable any chip. 
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° Parity Register Access 


Access of the parity control register does not cause ioden_ to be asserted, since the register is in 
the ram+ gate array on the sb_d bus, rather than the iod bus. 


Figure: 3.22 Parity Register Access 


sb_clk 
sb_as_ 
sb_ack32_ 
joden_ 


par_cs_[x] 


sb_rd 





e SCC/KB Mouse Access 


The 85C30 Serial Communications Controllers used for the serial ports and for the Key- 
board/Mouse ports have longer access times than other 8-bit peripherals. In addition, the mmu+ 
chip guarantees 1 uSecond of hold-off time between accesses. 


A 6 MHz 85C30 is assumed, with 180 nsec rd-datavalid delay, 200 nsec rd width, 300 tse- 
Adr-to-rd-datavalid, 200 nsec wr width, 10 nsec write-data-valid-to-write-asserted delay. 


Figure: 3.23 SCC/KB Mouse Access 


sb_ack8_ 
sb_rd 


jodcen_ 
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3.8.5 Protection Checking 


An access violation may occur on any device space cycle. When sb_as_ is recognized along with 
any access violation, no statistics update cycle will take place, and no device will be selected. 
Error reporting is done by the cache+ chip. The following rules must be satisfied to allow a cycle 
to take place: 


¢ if user_ is low, mmu_s must be low 


° if sb_rd is low or ctl[{1] is high, mmu_w must be high. 
ctl[0] must be low. 


* CtI[0] is used by the cache+ chip to report an address violation in which iu_a[31:29] were not 
either all ones or all zeroes. Ctl[1] is used to report a load-store cycle, which must not take place 
if the page is not writable. 


3.8.6 Statistics Updates 


Every successful device-space access will cause a Statistics update cycle to take place to the 
current page map entry. A read-modify-write cycle is done on the statistics byte (pm_wr[2]_). 
The mmu_a bit is set to one, and the mmu_m bit is OR-ed with one if this is a read cycle. 
Because of this cycle, the cache+ chip must guarantee that the high-order virtual address lines 
(sb_a[29:12]) does not change for 2 clocks after the assertion of sb_as_. 


Figure: 3.24 Statistics Updates 


sb_clk — al {J & = LJ 


sb_as_ 
sb_a{29:12) 
pm_wr[2)_ 


statistics 





mstat_oc_ (int 


As with the normal page map and segment map writes, the page map write enable signal is 
asserted in clock 2, and the mmu+ drives the statistics bits in the second half of clock 2 and the 
first half of clock 3. The write-enable signal is negated in clock 3. In order to provide address 
hold time, the input addresses may not change until clock 4. 
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3.8.7 Interrupts 


The Interrupt Register provides for software generation of interrupts and allows the CPU to 
disable all interrupts or only certain ones. It is cleared on sb_reset_, and has the following fields: 


31 24 

| Enabied Reserved Enabled Enabled Enable | 
| 14 10 8 Any | 
Address Type 1. Physical Address OxF500 0000 


Address Type I, Physical Address 
¢ Software interrupts may be generated on levels 6, 4, and 1 by writing a 1 into bits 27, 26, or 25 
when interrupts are enabled (bit 24 high). 





* All irq{13:1]_ inputs may be asynchronous to the system clock. 


¢ Level 15 interrupts (maskable only by the Enable Any bit) are captured from the sb_merr_ 
input. sb_merr_ is ignored on cpu read cycles, when the Cache+ chip would be generating a 
synchronous error. These cycles are identified by all sb_bgn_ negated and a one-clock-delayed 
version of sb_rd asserted. 


¢ Writing a zero to the Enable Interrupts bit (24) clears any pending level 15 interrupt. 
¢ Writing a zero to any of the Enable bits in the Interrupt Register only masks out that levels 
interrupt. It does not clear the source, with the exception of level 15 requests. This is different 
from the Sun-4 architecture, in that the periodic interrupts at levels 10 and 14 must be cleared by 
accessing their respective Limit Registers (see "Counters" below). 
See the SUN Calvin System Specification for a list of mappings between interrupt levels and in- 
terrupting devices. 

3.8.8 Counters 
The MMU+ has two microsecond-resolution counter/timers which provide periodic interrupts at 
levels 10 and 14. There are two counter registers and two limit registers. Interrupts occur when 
they are enabled in the Interrupt Register and the counter reaches the value preset in its 
corresponding limit register. 


¢ Each counter is set to 1.0 uSec on sb_reset_ and free-runs. 


¢ The least significant 10 bits of each counter always read as zeroes to allow for future expansion 
to sub-microsecond resolution. 


e When a counter reaches the value set in its limit register, it is set back to 1.0 on the following 
increment, and the Limit Reached bit is set. 


¢ Counter 0 interrupts at Level 10 when enabled. 


¢ Counter 1 interrupts at Level 14 when enabled. 


ee 
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+ Reading a Limit register clears its Limit Reached bit, clearing the pending interrupt. Clearing 
the level 10 or 14 bit in the Interrupt register does not clear a pending interrupt; it only masks 
it. 
¢ Each Limit register is set to all 0's on sb_reset_, allowing the counter to freerun. 
¢ Writing to a Limit Register will set its corresponding Counter back to 1.0 uSec. 
¢ Both counters may be read at any time, and are guaranteed by hardware not to increment during 
a word read operation. 


¢ Both counters are separately writable for testing purposes. They should not be written in normal 
operation as results would be unpredictable. 


Limit Counter Value 
Reached 


Figure: 3.25 Counter 


Counter 0 0xF3000 0000 
Counter 1 O0xF3000 008 





Figure: 3.26 2nd Counter 


Limit 0 OxF300 0004 
Limit 1 0xF300 000C 





3.8.9 I/O Register 
An 8-bit parallel port exists at Type 1 Physical Address OxF740 0000. It is a pseudo-bidirectional 
port which can read the value at its pins and has open-drain outputs. To use an individual bit as 
an input, it should be always written with a "1" to avoid contention on that pin. 
e All bits are set to 1's on sb_reset_. 


e See the SUN Calvin System Specification for the functional mappings of the bits. 


e Bits which may be used as outputs must have an extemal pullup resistor. 
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3.9 P2 Bus Interface Overview 


Illustrations of the P1/P2 connectors of the SPARC CPU-2CE card can be found in Section 2. The P1 
and P2 connectors are identical. 


3.9.1 P1/P2 Connector Numbering 

The CPU-2CE follows standard VME pin numbering of 3 rows of 32 pins on each connector. See section 
2 for the pin signals. 

3.10 Serial Interface A and B 

3.10.1 Serial Interface A and B Device Address 

The address of Serial Interface A is OxE2000000. 

On-Board Input/Output (OBIO) 

3.10.1.1 RS232/RS423 Jumper Selection 

The serial ports are RS-232-C or RS-423 with the default being RS-232-C. If RS-423 is needed, set the 
block before power up. Move the jumpers position to set RS-423. See the next page for the CPU-2CE 
defaults. The two ports are linked so both must be either RS-232-C or RS-423. See section 2 for pin 
signals. 

3.10.2 Serial Interface A/B Definition 

The A serial port interface supports asynchronous RS-423 with full modem control lines. For most 
applications, the interface will be directly compatible with RS-232 equipment as well. In addition to the 
RS-423 interface logic, four of the signals are brought out to separate connector pins via RS-423 
compatible drivers and receivers. Transmit Data (TxD), Receive Data (RxD), Request to Send (RTS) and 
Clear to Send (CTS) signals are provided for use in electrically noisy environments or where longer cable 
lengths are required. 

3.10.3 Serial Interface A/B Performance 

Asynchronous Speed: 19.2 Kbaud 

The maximum baud rate supported by the Boot PROM on the SPARC CPU-2CE is 19.2K bits/second and 
assumes a 1/16 bit clock divisor. Faster bit rates can be programmed for custom applications. Refer to 
the Z8530 SCC Technical Manuals for more details. For reference, the clock input to the SCC for baud 
rate generation is 4.9152 MHz. 

The A/B serial port interface does support Synchronous Serial Communications. RS-232 limits 


transmission rates in asynchronous mode to 20K bits/second, and RS-423 limits data rates to 100K 
bits/second. 


Page 3-64 FORCE COMPUTERS 


SPARC CPU-2CE Technical Reference Manual Hardware 
lea tea na 


Figure: 3.27 RS-232/423 Jumper Blocks 


BOARD JUMPERS 
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3.11 Keyboard/Mouse Interface 

3.11.1 Keyboard/Mouse Device Address 

The keyboard/mouse address is OxFO000000. 

On-Board Input/Output (OBIO) 

3.11.2 Keyboard/Mouse Interface Definition 

The keyboard/mouse serial interfaces are implemented with a Z8530 Synchronous Serial Communications 
Controller. The SCC features two programmable serial channels with built in baud-rate 

generators. The clock input to the SCC for baud-rate generation is 4.9152 MHz and is independent of 
the IU clock. 


Reset of the keyboard/mouse SCC is forced at power-up by asserting both read and write strobes 
simultaneously. 


Mouse and keyboard data are transmitted and received over connector J1101 (DB-15). All data signals 
are TTL-compatible and cannot be direct-connected to RS-232, RS-423, or other non-TTL compatible 
equipment. 


3.11.3 Specifications 

The keyboard/mouse interfaces are designed to connect to Sun type-3 and type-4 keyboards. The Boot 
PROM will interrogate the interface upon power-up to determine if a keyboard is present. If not, the 
PROM expects a terminal to be connected to the Serial A port. 


NOTE: The keyboard/mouse interface is intended for use with Sun keyboards only; custom serial 
expansion via this interface requires Boot PROM modifications. 
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APPENDICES TO THE HARDWARE USER’S MANUAL 


The CPU Card Schematic Diagrams 


This appendix provides schematic diagrams of the key interfaces in the SPARC CPU-2CE for better 
understanding. 


All of the included schematics and drawings are listed below: 
DWG Schematics 

Serial Cable Drawing 

Ethernet Cable Drawing 

Reader Comment Card 


Product Error Report 


eT 
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ger unit and a floating-point coprocessor 
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Features 


single-chip pin-compatible replacement for the Cy- 
press CY7C601 integer unit and either the WEITEK 
WTL 3171 or the Cypress CY7C602 floating-point 
coprocessor 


Lower power and real estate requirements for both 
current and new designs ; 


Higher floating-point performance (comparison) 


Complete binary software compatibility with the Cy- 
press (CY7C601/602), the Cypress-WEITEK 
(CY7C601/WTL 3171), and the LSI Logic 
L64811 IU/L68414 FPU chip sets 


Available for bus clock speeds of 25, 33, and 40 MHz 


a TT SE PL TR EE EE a TE TS EE 


Description 


The W8701 is a single-chip replacement for the Cypress 
CY7C601/CY7C602 SPARC” RISC chips. It contains a 
SPARC processor and floating-point coprocessor on a 
single die. The W8701 can be used as a production up- 
grade to current designs by plugging the W8701 into the 
CY7C601 processor socket, and leaving the coprocessor 
socket empty. This will provide higher throughput, lower 
power requirements,and reduce cost while maintaining 
full software compatibility. 


The W8701 is an implementation of the version 7.0 
SPARC architecture. It provides complete compatibility 
with the Cypress SPARC chip set or the Cypress-WEITEK 
combination chip set. 


This document covers the features unique to the W8701 
and provides complete electrical and mechanical specifica- 
tions. 
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Signal Description 


In this chapter we will describe the W8701’s external signal NOTATIONAL CONVENTIONS 


interface. : : : : : 
Signals that arc active low will be marked with a suffixed* 


dash (-) after the signal name. All other signals arc active 
high. “Active” and “asserted” are equivalent terms, as are 
“inactive” and “de-asserted.” When signals are shown as 
ones and zeroes, a “1” always indicates a voltage near 
VCC, while a “O” indicates a voltage near GND. 


Memory subsystem interface signals 
Interrupt and control signals 
Integer to floating-point unit signals 


Power and clock signals 


Signal______‘[Desenpion——SSCSCS~C~—SCSCSSCSC~*Y 


A(31:0] 
AOE- 
ASI[17:0] 
BHOLD- 
COE- 
D[31:0} 
DOE- 
DXFER 
FNULL 
IFT- 
NULL 
LDSTO 
LOCK 
MAO 
MDS— 
MEXC— 
MHOLDA-— 
MHOLDB- 
RD 
SIZE[1:0] 


Address bits 

Address Output Enable 
Address Space ID 

Hold signal from 1/0 bus 
Control Output Enable 
Data 

Data Output Enable 

Data Transfer 
Floating-point unit null cycle 
Instruction cycle flush trap 
Integer unit null cycle 


Load and store (atomic) 


Bus lock (multi-cycle instruction) 


Memory address Output select 
Memory data strobe 

Memory exception 

Hold signal from memory 

Hold signal from memory 
Read access 

Bus transaction size 

Write enable 

Write Tag 


Figure 2. Memory system interface signals 


Tri-state Output 
Input 

Tri-state Output 
Input 

Output 
Tri-state 

Input 

Tri-state Output 


‘Output 


Input 

Output 
Tri-state output 
Tri-state output 
Input 

Input 

Input 

Input 

Input 

Tri-state output 
Tri-state output 
Tri-state output 
Tri-state output 
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Signal Description, continued 


Signal Pin Ware) Description 


ERROR- Internally generated error 


INTACK Interrupt acknowledge 


IRL{3:0] Interrupt request level 
RESET— Reset input 
TOE- Test output enable 





Figure 3. Interrupt and control signals 


Signal in Name 


Floating-Point Inst. Buffer 1 Output 
Floating-Point Inst. Buffer 2 Output 
Flush Floating-point Unit Output 
FPU Exception Acknowledge Output 
Instruction Fetch Output 





Figure 4. Integer unit to floating-point unit signals 


Signal (Pin Name) Description 


Floating-Point CC bits Output 
Floating-Point CC bits valid Output 
Floating-Point Exception Output 
Hold signal from FPU Output 





Figure 5. Floating-point unit to integer unit signals 


Signal Pin Name 


Main Clock 
Main Internal VCC 
Output Driver VCC 


Input Circuit VCC 
Main Internal GND 
Output Driver GND 
Input Circuit GND 





Figure 6. Power and clock signals 
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DC Specifications 
ABSOLUTE MAXIMUM RATINGS 


Storage Temperature -65 °C to + 150 °C 
Ambient Temperature with Power Applied -55 °C to + 125 °C 


Supply Voltage to Ground Potential" -0.5 VDC to +7.0 VDC 
DC Voltage Applied to Outputs in High Z state -0.5 VDC to +7.0 VDC 
DC Input Voltage ‘ -3.0 VDC to +7.0 VDC 
DC Output Low sink Current 30 mA 

DC Input Current -10 mAto +10 mA 
Ambient Temperature” (Ta) 0 °C to +70 °C 


Supply Voltage (Vx) +4.5 VDC to + 5.5 VDC 
Power Dissipation (all outputs floating) 2.2 watts 


* Ambient temperature is defined as the case temperature just before power is applied 
All power and ground pins must be connected before power is applied. 


Figure 7. Absolute maximum ratings 





DC CHARACTERISTICS 


Output High Voltage Vee = Min, loy = -2.0 mA 
Output Low Voltage Vee = Min, lop = 8.0 mA 
Input High Voltage 

Input Low Voltage 

Input High Current Vee = Max, Vin=Voc 

Input Low Current Vee = Max, Vin =Vss 


Vcc=Max, 


Output Leakage Current Vara VesSVeureVeo 


Supply Current Voc = Max, f = 40 MHz 
Supply Current Voc = Max, f = 33 MHz 





Figure 8. DC characteristics 


PIN CAPACITANCE 















Input Capacitance (Vec = 5.0 VDC, Ta = 25 °C, f = 1 MHz) 
Output Capacitance (Vcc = 5.0 VDC, Ta, = 25 °C, f = 1 MHz) 
V/O pin Capacitance (Veg = 5.0 VDC, Ty = 25 °C, f = 1 MHz) 


10 pF maximum 


12 pF maximum 





15 pF maximum 


Figure 9. Pin capacitance 
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AC Specifications 
NOTATIONAL CONVENTIONS 


The individual AC specifications are not numbered; they from the table in figure 10. Future editions will use 
are identified by the signal name and a parameter type © WEITEK’s usual notation for AC specifications. 


Propagation delay time of an output referenced to a given clock edge 
Hold time of an output referenced to a given clock edge 
Setup time of an input referenced to a given clock edge 


Hold time of an input referenced to a given clock edge 


Turn off time for a tri-state output driver after the rising edge of DOE— 


Turn on time for a tri-state output driver after the falling edge of DOE- 
The rising edge of clock CLK 

The falling edge of clock CLK 

Output Load Capacitance: A load capacitance of 50 pF is assumed 


All times are given in ns. Clock references are made with respect to the 1.5 VDC level of the clock. HOLD signal T,, from 
CLK+ must be 8 ns or less @ 33 MHz and 7ns or less @ 40 Mhz. t; = t; < 3ns. Inputs switch 0 to 3.0 VDC 





Figure 10. AC timing specification conventions 


OUTPUT SIGNALS 


Parameter Ref Clock Edge 33 MHz | 40MHz | 
MAX 


A(31:0] 
ASI[7:0] 
SIZE[1:0] 
RD 
LDSTO 
LOCK 
WE- 
WRT 
D[31:0] Out 
DXFER 
ERROR 
FNULL 
INTACK 
INULL 


4 a 
7 7 
7 7 
v4 7 
7 7 
iz. 7 
7 i 
7 7 
4 4 
2 2 
3 3 
3 3 
3 3 
3 3 





Figure 11. W8701 output timings, relative to CLK 
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AC Specifications, continued 


OUTPUTS WITH RESPECT TO HOLD AND MAO 


HOLD+/- 
3 MAO+/— 
2HOLD+/— 
2 HOLD+/— 


‘A/CTL signals include: A[31:0], AS[17:0}, SIZE[1:0], RD, LDSTO, LOCK, WE-, and WRT 
2 The HOLD in “Reference Edge” above includes MHOLDA-, MHOLDB-, BHOLD-, and FHOLD 
3 MAO may be deleted 



















Figure 12. W8701 outputs with respect to HOLD and MAO 


INPUTS WITH RESPECT TO CLK 


33 
Ts Tu Ts Tui Ts Tu Ts Tu 
min min max max min min max max 


D[31:0] In 
MEXC— 
MHOLDA-* 


MDS- 

IRL[3:0] 

RESET- 

AOE- 

TOE- 

‘ This signal description includes MHOLDB-, and BHOLD- 
5 This signal description includes COE-, and DOE- 





Figure 13. W8701 inputs (setup and hold times) with respect to CLK 
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AC Specifications, continued 
CLOCK INPUT SPECIFICATIONS 


[Parameter | Description | Min-Max | 33MHz | 40MHz | Unit | 
Te 30 ns 


















Clock Period 
Tan Clock High Time 13 
Tot Clock Low Time 
Ten Clock Rise Time 





Tix Clock Fall Time 


Figure 14. Clock input specifications 


50 pF 


Test Conditions: 
tp=t)< ps < 3ns 
Vret = 1.5 VDC 


DUT = Device Under Test input levels 0 > 3.0 VDC 





Figure 15. W8701 output loading circuitry Figure 16. Clock input timing diagram 
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Pin Configuration 







vcc TOE- TO" 
Sco 
SCG 
=e [= 
Soi 
Seco 
pol=| =[= 
pool 

















W8701 SPARC Processor 
207-pin PGA 






Top View 
Cavity Down 







Fexc- | NULL | LOSTO AI? 


} 10 [ we | om |cox| war ] cro | vee | oro] ero] ve] vee foe | vee] ow | we | we | ve 
exe | ew | 0 oven] ao [are | ase] vee] om | oxe[ ae | a | ae | sce] a | re | re 
vce | oe | oe] sae aco] on ace | ave] om] om | a | me | me | om | oe |e | 20 | 
SC] ve | ov | ve | ve foo [are] ase] sr] ow fe fo [a | # [eo [ao | oo 
A B Cc 18) E F G H J K E M N Pp R T U 


Pin 1 Identifier 





Figure 17. Pin configuration for the W8701 
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Package Dimensions 
207 Pin Grid Array 


Dimensions 
Symbol Inches Millimeters 


0.100 + 0.015 2.3410 + 0.38 


0.180 typical 4.570 typical 
0.050 typical 1.270 typical 


1.750 sqt+0.020 | 44.45+0.51 
9990800000000 Standott 1.600 sq+0.020 | 40.64+0.508 


Bottom View Side View 


4 
PiNA1 Location Top View Come ees 87 OSes 8-Eae 


0.065 diameter typ | 1.650 diameter typ 
0.100 typical 2.540 typical 





Figure 18. W8701 Physical Dimensions and package in- 
formation 





Ordering Information 


Package Type Speed Grade Temperature Range (case) Order Number 


207-pin ceramic PGA W8701-025-GCD 


207-pin ceramic PGA W8701-033-GCD 
207-pin ceramic PGA W8701-040-GCD 





Figure 19. Ordering information 
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NCR 53C90A, 53C90B 


Figure 2. NCR 53C90 and 53C90A Pin Configurations 


spas 1, A3 
SDI5/ A2 
SDI6/ Al 
SD17/ AO 
SDIP/ CS/ 
= RD/ 


Vs5 NCR 53C90 WR/ 


$D00/ DREQ 
SDOI NCR 53C90A DACK/ 


$DO2/ CLK 
$D0O3/ 68-Pin PLCC IGS 
Vice TGS 
$N04/ Ma 
SDO5/ RSTI/ 
$D06/ ATNY/ 
$N07/ Ol 
SDOP/ C/I! 


80 78 76 74 72 70 68 66 
RESETO 


~ WCR 53090 
NCR 53C90A 


$103/ . 80-Pin QFP 

Vss FF 

sD04/ 

SDO5/ 

SDO6/ 

SD07/ 

SDOP/ 
Vv 


REQI/ 
26 28 30 32 34 36 38 40 2 





2 NCR SCSI Products 


NCR S3C90A, 530908 


Table 1. Host Processor and DMA Interface Pins — PLCC Package 











Active-high data bus connected to the DMA controller, CPU and buffer memory. 
Lach pad contains a pull-upto V.. (125K minimum). 





4-1, 68-65 


DB7-DBO ce 





bp 
Active-high chip reset. Reset must be asserted for two CLK periods, mimimum, 
after the voltage on the power pins has reached V,,,, min. ‘This input must not 

be connected to RESETO. 








Active-high reset output. ‘This output is always asserted when the RESET input 
is true OR may be asserted when the SCSI reset signal is active if bit 6 of the 
Config | register is cleared and the host has not serviced the interrupt (gener- 
ated because of SCSI reset) within 1-2 ms (depending on CLK frequency and 
clock conversion factor). Refer to Bus Initiated Reset. 















Active-low, open drain interrupt signal to the microprocessor. It is latched on 
the rising edge of CI.K and may be cleared by reading the interrupt register or 
by a host hardware reset, or by a host software reset (but not by a SCSI reset). 

‘This output cannot be disabled internally. 













Active-high address bus which specifies one of the ASPs internal registers for 
reading or writing. Used with CS/, ignored with DACK/. 








Active-low chip-select signal that enables access to the ASPs internal registers. 
CS/ accesses any register, including the FIFO, while DACK/ accesses only the 
FIFO. CS/ and DACK/ must never be active at the same time. 


55 RD/ Active-low read signal that enables ASP data onto DB7-DBO. CS/ or DACK/ must 
also be active. 


Active-low write signal that strobes DB7-DBO data into the ASP. CS/ or DACK/ 
= Z 


must also be active. 
wal 
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‘Tri-state active-high IDMA request to the DMA controller. DREQ will be true as 
long as the FIFO has at least one byte to send to memory, or has room to receive 
at least one byte from memory, depending on data direction. 







Active-low DMA acknowledge from the DMA controller. DACK/ accesses the 
FIFO only, while CS/ accesses any register, including the FIFO. CS/ and DACK/ 
must never be active at the same time. DACK/ must toggle true then false for 

every byte transfered. Refer to DREQ Hi Z Bit in Config 2. 


Square wave clock that generates internal chip timing. The maximum 
frequency is 25 MHz, with a 35% to 65% duty cycle. The minimum frequency 
required for asynchronous SCSI transmission is 10 MHz. The minimum 
frequency required for synchronous transmission is 12 MHz. The synchronous 
transmission rate is equal to the CLK input period divided by the value in the 
synchronous transfer period register. ‘The asynchronous transfer rate is 
indirectly affected by CLK frequency. Refer to Dara Transfer Rate. 















NCR 53C90A, 53C90B 


Table 2. SCSI Bus Interface — PLCC Package 
[Pin | signat —[type[Deseription 


SDI0/-SD17/, Schmitt trigger, active-low SCSI data/parity bus. In single-ended mode (DIFFM = 0) 
SDIP/ these inputs are SCSI data bus signals. In differential mode (DIFFM =!) these are 
bi-directional data and parity signals for external SCSI bus transceivers. 


48 mA, open drain SCSI data parity bus. In single-ended mode (DIFFM =0) these 
outputs are active-low SCSI data signals. In differential mode (DIFFM =1) these 
outputs are used to control the direction of external differential transceivers, with 
high meaning output to the SCSI bus, low meaning input from the SCSI bus. 

















17-20, SDO0/-SDO7/ oO 






26 sSDOP 0 


3) ACKO/ 48 mA, open drain, active-low SCSI acknowledge signal. This output is only 
asserted when the ASP is in initiator mode. 
33-35 MSGO/, 48 mA, open drain, active-low SCSI phase signals. These outputs are only 
C/DO, 1/00 asserted when the ASP is in target mode. 
ATNO/ 48 mA, open drain, active-low SCSI attention signal. This output is only asserted 
when the ASP is in initiator mode. Several ASP commands will set ATN. It is also 
37 RSTO/ 
pulse length is 25-40 us, depending on CLK frequency and clock conversion factor. 
Refer to Bus Initiated Reset. 


asserted when the ASP detects an incoming parity error if parity checking is 
enabled. 

Ewa SELI/ = Schmitt trigger, active-low SCSI select input. 

a BSYI/ rz Schmitt trigger, active-low SCSI busy input. 


REO | a ee Schmitt trigger, active-low SCSI request input. 


_ ACKI/ | 1 | Schmitt trigger, active-low SCSI acknowledge input. 


43 MSGI/ Schmitt trigger, active-low SCSI message input. 


efi Schmitt trigger SCSI control/data input. 


Schmitt trigger SCSI input/output input. 


Schmitt trigger, active-low SCSI attention input. 
NCR SCSI Products 5 


















48 mA, open drain SCSI select signal. In single-ended mode this output is active- 
low. In differential mode it is active-high. 






48 mA, open drain SCSI busy signal. In single-ended mode, this output is active- 
low. In differential mode it is active-high. 










48 mA, open drain, active-low SCSI request signal. This output is only asserted 
when the ASP is in target mode. 




























48 mA, open drain SCSI reset signal. In single-ended mode this output is active- 
low. In differential mode it is active-high. The ASP drives this signal true only 
when the host writes the SCSI bus reset command to the command register. The 














Schmitt trigger, active-low SCSI reset signal. When this input is true, the ASP will 
automatically disconnect trom the SCSI bus. If bit 6 in the Config | register is zero, 
the ASP will interrupt the host. If the interrupt is not serviced within 1-2 ms, the 
ASP will reset its host processor. Refer to Bus Initiated Reset. 













Active-high initiator group select signal. ‘This pin is high whenever the ASP isin 
initiator mode. It is used in differential mode to enable the initiator signals 
(ACKO/, ATNO/). When low, the ASP should be receiving these signals. 


NCR 53C90A, 53C90B 


Table 3. Power and Ground Pins 


16, 21, 27, 32, 38, 64 10, 11, 16, 22, 23, 29 Ground. NCR recommends a ground plane be used. 
30, 37, obF 


Table 4. 53C90 and 53C90A only — PLCC Package 


[Pin [Sint [Tope] Deesipion 


a 
3 ES 


Table 5. 53C90B only — PLCC Package 


rin [serat[Wee[ Deets CCS 


: 


Pett eaten 












Active-high target group select signal. This pin is high whenever the ASP is in 
target mode. It is used in differential mode to enable the target signals (REQO/, 
MSGO/, C/DO, 1/00). When low, the ASP should be receiving these signals. 












Differential mode enable. When this pin is grounded, the ASP operates in 
single-ended mode, with separate SCSI data input and output buses. When this 
pin is high, the ASP operates in differential mode, with bi-directional SCSI data 
on the SDI pins and active-high differential transceiver enables on the SDO pins. 












This pin is sampled during reset to put the chip in differential mode or single- 
ended mode, it then switches function to become the TGS output. An internal 
pull-up pulls it high for single-ended mode, while an external IK pull-down will 
place the C90B in differential mode. 








There are two kinds of reset, power-up reset and running-reset. On power-up, 
the state of this pin is sampled as the voltage on the power pins rises through 3 
volts (approximately). A running-reset is a host hardware reset that occurs 
sometime later. A running-reset will sample this pin until the 10th rising edge of 
CLK after RESET goes true (high). This is enough time for the internal pull-up 
to pull it high. Whatever state it’s in on the 10th clock will determine the mode. 
The TGS function will be disabled until the 12th rising edge of CLK affer RESET 
first goes true and RESET is false. 


When RESET is false (low), and 12 clocks have occured since RESET first went 
true, this pin becomes the TGS output, an active-high target group select signal. 
This pin is high whenever the ASP is in target mode. It is used in differential 
mode to enable the target signals (REQO/, MSGO/, CDO/, I00/). When low, the 
ASP should be receiving these signals. 
























Active-high data bus parity for host, DMA, and memory data bus. Four bits in 
Config 1 and Config 2 control parity generation and checking. 
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Differences from 53C90 


Supports three-byte message exchange SCSI-2 
tageed-queuing 


Addcd sclect with ATN3 command 
Added target DMA abort command 
Added interrupt polling bit 

Added second configuration register 


Improved immunity to cable impedance mismatches and 
improper termination 


‘Tri-state DMA request output 

Cut leakage current on SCSI input pins when powered off 
Relaxed register timings 

Relaxed DMA timings 

Relaxed CLK duty cycle 

Lengthened read data access time 


NOP required less often 
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Functional Description 


The ASC SCSI data bus has a set of inputs and a set of 
outputs. This allows the ASC to be used in either single- 
ended mode or differential mode. In single-ended mode, 
the inputs are usually connected to the outputs on the 
circuit board. In differential mode, the SDI (SCSI Data 
Input) pins become bi-directional data pins, while the 
SDO (SCSI Data Output) pins become enable signals for 
the differential transceivers. Separate enables are 
required, because during arbitration two data bus signals 
must be outputs while the other six must be inputs. ‘lwo 
signals, TGS and IGS, control the direction of the external 
transceivers, allowing the ASC to dynamically switch 
between initiator and target roles. 


The ASC has a command set that allows it to perform 
common SCSI sequences at hardware speed without host 
intervention. Its on-chip FIFO may be accessed simulta- 
neously by the SCSI bus and either the host processor or 
the host DMA controller. All command, data, status, and 
message bytes pass through the FIFO on their way to or 
from the SCSI bus. Most ASC commands have two 
versions: DMA and non-DMA. When DMA instructions 
are used, data will pass between memory and the SCSI 
bus with the FIFO acting as temporary storage when the 
DMA channel is temporarily shut down by a higher 
priority event such as DRAM refresh. 


The FIFO also helps speed execution during non-DMA 
transfers. For example, in initiator role, the host proces- 
sor will load the CDB (Command Descriptor Block) and 
optionally one or three message bytes into the FIFO, , 
issue one of several selection commands and wait for an 
interrupt. The ASC will wait for bus-free, arbitrate for 
the bus again and again until it acquires it, send the 
message bytes followed by the CDB, then generate an 
interrupt. Meanwhile, a multi-tasking host may con- 
tinue with other tasks. 


In target role, the host processor will enable selection, 
then wait for an interrupt. Eventually, an initiator will 
select the ASC and will then automatically step through 
the arbitration, selection, and command phases before 
generating an interrupt. When the interrupt occurs, the 
entire command descriptor block will be in the FIFO 
along with any message bytes sent by the initiator. 
Combination commands such as these, are identified 
with the sequence suffix in the Zable of ASC Commands. 
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After selection phasc has been successfully completed, 
the ASC may transfer bytes in any of the SCSI informa- 
tion phases whether operating in initiator or a target 
tole. ‘he ASC supports disconnect/reselect in both 
initiator and target roles, making high performance 
multi-threaded systems casy to implement. 


‘The ASC may transfer data phase bytes across the bus 
synchronously, at speeds up to 5 MB/S, or asynchro- 
nously at speeds up to 6 MB/S. Refer to Data Transfer 
Rate. ‘Vhe difference between the two is transparent to 
the user except that the synchronous offset and the 
synchronous transfer period registers must be pro- 
grammed prior to synchronous data transfer. ‘he 
default, after hardware or software reset, is asynchro- 
nous transmission. 


Data phase bytes will usually be transferred using DMA. 
The host processor will program an external DMA con- 
troller, program the ASC transfer count, issue an ASC 
data transfer command (there are several), then wait for 
an interrupt. he DMA controller and the ASC will 
transfer all the data without host processor intervention. 


To end the SCSI transaction, the ASC target will place a 
status byte and a message byte in the FIFO, then issue a 
single command (there are two to chose from) which 
will cause the ASC to first assert status phase, send the 
first byte, assert message in phase, send the second byte, 
disconnect from the SCSI bus (after the initiator releases 
ACK (Acknowledge)) and interrupt the host processor. 


The end of a SCSI transaction is similar for an ASC 
initiator except that it receives two bytes into its FIFO. 
The initiator prevents the target from disconnecting by 
holding ACK asserted on the bus while the host proces- 
sor examines the status and message bytes. If both bytes 
are good, the message accepted command is used to 
instruct the ASC to release ACK, which allows the target 
to disconnect which causes the initiator to interrupt its 
host and report the disconnect. If the status and mes- 
sage bytes are not good, the host should first issue the set 
ATN (Attention) command before issuing the message 
accepted command. This instructs the ASC to assert ATN 
before releasing ACK, which should cause the target to 
request message out phase rather than disconnect. 


Bus Initiated Sequences 
Selection 
Resclection 


SCSI bus reset 


Selection or reselection sequences occur in the discon- 
necicd state when the ASC is selected or reselected by 
another initiator or target, if the enable selection or 
reselection command had previously been received by 
the ASC. 


In addition to responding to bus initiated events, the ASC 
may initiate a bus event by using one of several selection - 
or reselection commands. If one of these commands 
starts executing, i will clear enable selection/reselection 
after arbitration has been won. Normally the host 
processor will have 250 ms (ANSI recommended selection 
time-out period) after the chip disconnects from the bus 
to re-enable bus initiated events. If the time-out is 
exceeded, an initiator or target which is attempting to 
connect to the ASC, may time-out and abort. 


If, on the other hand, the bus initiated event occurs 
before the command starts executing, the FIFO and com- 
mand register will be cleared, and any further writes by 
the host processor will be ignored until the interrupt 
register is read. Since a selection/reselection command 
requires that something be placed in the FIFO, these 
bytes will be lost, as will any command written to the 
command register. The interrupt handler that services a 
selection/reselection command will have to examine the 
bits in the interrupt register to detemine if the ASC 
selected another device, or if it was selected by another 
device. The former case will cause a function complete 
interrupt, the latter case will cause a selection/reselec- 
tion interrupt. 
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Table 6. ASC Register Set 
Address (hex) 


‘Transfer counter LSB 


‘Transfer counter MSB 


FIFO 
Command 
Stratus 
Interrupt 


Sequence step 


NCR reserved 
NCR reserved 


> 0 DOAN DN &® WwW LH 


ioe] 


Register Set 


Some ASC registers have different meanings during 
reads than writes. When CS/ is true, the register being 
accessed is determined by either RD/ or WR/ together 
with the address pins AO-3. ‘Ihe FIFO may be accessed 
using either CS/ or DACK/ together with RD/or WR/. 
Address pins A0-A3 are ignored when DACK‘/is active, 
but must be driven when GS/ is active. 


Transfer Count (Write address 0,1) 


These two registers together form a 16-bit transfer count 
for DMA operations. ‘lransfer count specifies the 
number of bytes that are to be transferred over the SCSI 
bus. Values written to these two registers will be stored 
internally and loaded into the transfer counter by any 
DMA command. These values remain unchanged while 
the transfer counter decrements. Thus, successive 
blocks of equal size may be transferred without repro- 
gramming the count. They may be reprogrammed any 
time after the previous DMA operation has started, 
whether it has finished or not. Zero specifies a maxi- 
mum length count (65536). ‘hese registers are not 
changed by any reset; their states are unpredictable 
after power-up. 
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FIFO flags/sequence step 
Configuration | 


Configuration 2 
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‘Lransfer count LSB 
‘Transfer count MSB 
FIFO 

Command 
Destination bus ID 
Select/reselect timeout 
Synchronous period 
Synchronous offset 
Configuration | 

Clock conversion factor 
‘lest mode 


Configuration 2 


Transfer Counter (Read address 0,1) 

A read from these two addresses will return the value 
currently in the counter. DMA commands use the coun- 
ter to terminate a transfer. Any DMA command will 
load count into the counter. A DMA NOP 80h will load 
the counter while the non-DMA NOP 00h will not. 


With one exception, non-DMA commands do not use 
the counter. ‘he exception is when the ASC has been 
selected, it decodes the group code field of the CDB 
(Command Descriptor Block), loads the counter with 
the number of bytes in the CDB, then decrements once 
for every byte received. 


‘The transfer counter decrements on the leading edge of: 


Decremented by 


Data in phase DACK/ 
Data out phase REQO/ 


Initiator Decremented by 


Synchronous data in DACK/ 





Asynchronous data in ACKQ/ 
Data out DACK/ 
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Note that DAcKs can decrement the counter even if RID/ 
or WR/do not go true. False DACK/s can cause the 
counter to get out of sync with the data stream, leading 
to subtle crrors that are difficult to trace. When false 
DACK/s are expected to interfere with a temporarily 
suspended DMA operation, the DREQ Hi-Z bitin 
Config 2 should be set. 


FIFO Register (Read/write address 02) 


The FIFO ts a 16 by 9-bit first-in-first-out buffer between 
the SCSI bus and memory. It is accessible by the host 
processor at this address. It is also accessible by an 
external DMA controller and by the SCSI bus. The DMA 
may access the FIFO by asserting DACK/ together with 
either RD/or WR/. When accessed by CS/, the address 
bits must be valid. When accessed by DACK/, the 
address bits are ignored. The bottom FIFO element and 
the FIFO flags are initialized to zero during hardware 
reset, software reset chip and at the beginning of bus 
initiated selection or reselection. The contents of the 
rest of the FIFO are not changed by any reset, but when 
the flags are zero, successive FIFO reads will always 
access the bottom register. 


Command Register (Read/write address 03) 


The command register is a two deep 8-bit read/write 
register used to give commands to the ASC. Up to two 
commands may be stacked in the command register. 
The second command may be written before the ASC 
completes (or even starts) the first. Reset chip, reset SCSI 
bus and target stop DMA execute immediately, all others 
wait for the previous command to complete. The last 
executed (or executing) command will remain in the 
command register and may be read by the host proces- 
sor. Reading the command register has no effect on its 
contents. The command register will be cleared by any 
of the following conditions: 


Hardware, software or SCSI bus reset 
SCSI bus disconnect 

Bus-initiated selection or reselection 
Select command 

Reconnect command if ATN is set 
Select or reselect time-out 

Target terminate command 


Parity crror deiccted in target mode 


* Assertion of ATN in target mode 
¢ Any phase change in initiator mode 


* [Illegal command 


If two commands are placed in the command regisicr, 
two interrupts may result. If the first interrupt is not 
serviced before the second finishes, the second interrupt 
is stacked behind the first. When the interrupt register 
is read by the host to service the first interrupt, the con- 
tents status register, sequence step register, and interrupt 
register will change to describe the second interrupt. 


Figure 5. Command Register (Read/write address 03) 


7 6 5 4 3 2 l 0 





Bit 7 (Enable DMA) 

When bit 7 is not set, the command is a non-DMA 
instruction. When it is set, the command is a DMA 
instruction. DMA instructions will load the internal byte 
counter with the value in the transfer count register 
(without changing the count register) then transfer data 
until that count decrements to zero. If the transfer 
terminates prematurely, the bits in the status , sequence 
step, and interrupt registers will indicate why. 


Bits 6-0 (Command code) 

The ASC commands are shown in Table 19. Bits 4,5 and 6 
specify a mode group. Commands from the miscellane- 
ous group may be issued at any time. Commands from 
the disconnected, target or initiator groups will only be 
accepted by the ASCif it isin the same mode asthe __ 
command when it falls to the bottom of the command 
FIFO. Otherwise, an illegal command interrupt will be 
generated. For example, after hardware or software 
reset, the ASC will be in the disconnected state. A 
command from either the target group or the initiator 
group will cause an illegal command interrupt. An 
enable selection or reselection command by itself will 
not change modes. However, if another SCSI device then 
selects the ASC, it will be in the target state; if another 
device reselects the ASC, it will then be in the initiator 
state. Similarly, any select command will place the ASC 
in initiator mode, while the reselect sequence command 
will place the ASC in target mode. 
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Status Register (Read address 04) 

The satus register contains important flags that indicate 
various conditions. All but the phase bits are latched. 
The phasc bits are live indicators of the state of the SCSI 
bus. All the latched bits except the terminal count are 
cleared by reading the interrupt register. 


Figure 6. Status Register (Read address 04) 


jose] ae J me fre [we] se] on | no | 
7 6 2 4 3 2 ] 0 














Data out 
Data in 
Command 
Status 
ANSI reserved 
ANSI reserved 


Message out 





Message in 


Bit 7 (Interrupt) 

This bit is set whenever the ASC drives the INT output 
true. It may be polled. It is buffered from the actual 
output, so that in wired-OR (shared interrupt) designs, 
this bit will indicate whether the ASC is attempting to 
interrupt the host processor. ‘This bit is reserved by NCR 
in the 53C90. Hardware reset or software reset chip or a 
read from the interrupt register will release an active 
INT signal and also clear this bit. 


Bit 6 (Gross error) 
This bit is set when one of the following has occurred: 


The top of the FIFO is overwritten 
The top of the command register has been overwritten 


Direction of DMA transfer is opposite to the direction of 
the SCSI transfer 

An unexpected phase change in initiator role during 
synchronous data phase 
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Gross error does not cause an interrupt, it may be 
deiccted only while servicing another interrupt. The bit 
is cleared by reading the status register if the interrupt 
output is asserted. It will also be cleared by hardware 
resct, or software reset chip (but not SCSI reset). 


Bit 5 (Parity crror) 

This bit will be set if parity checking is enabled in the 
Config | register and the ASC detects a SCSI parity error 
on incoming command, data, status or message bytes. It 
will be cleared by reading the interrupt register if the 
interrupt output is asserted. Hardware reset or software 
reset chip will clear this bit (but not SCSI reset). 


Bit 4 (Terminal count) 

This bit is set when when the transfer counter decre- 
ments to zero. It resets when the transfer count is 
loaded. Since a DMA NOP 80h command will load the 
transfer counter, it will also clear this bit. Note that a 
non-DMA NOP 00h will not load the counter and will 
not clear this bit. Reading the interrupt register will not 
clear this bit. Hardware reset or software reset chip will 
clear it (but not SCSI reset). 


Bit 3 (Valid group code) 

The name of this bit has changed from transfer com- 
plete in the 53C90 to valid group code in the 53C90A and 
53C90B; but it’s function remains the same. 


When the ASC is selected, it decodes the group code field 
in the first byte of the command descriptor block. If the 
group code matches one defined in ANSI X3.131-1986, this 
bit will be set. An undefined group code (designated 
reserved by the ANSI committee) leaves it not set. If the 
SCSI-2 bit is set in the Config 2 register, group 2 
commands will be recognized as ten-by te commands 
and the bit will be set. If the SCSI-2 bit is cleared, 

group 2 commands will be treated as reserved 
commands. Groups 3 and 4 are always treated as 
reserved commands. A reserved group command will 
cause the ASC to request 6 command bytes. The ASC 
recognizes group 6 as six-byte vendor unique commands 
and group 7 as 10-byte vendor unique commands. The 
valid group code bit will be cleared by reading the 
interrupt register if the interrupt output is asserted. It 
will also be cleared by hardware reset or software reset 
chip (but not by SCSI reset). 
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DC Electrical Characteristics 


Absolute Maximum Stress Ratings 


[Parameter | Symbol [ Pins [Test Conditions [Min [Max [| Unit | 





Storage temperature | 3 150 i 
Supply voltage 
Input voltage 
Latch-up current : -2V <V.< +8V 
Electrostatic discharge Human body model 
SCSI pins 100 pF at 15K ohms 
Other pins 100 pl’ at 15K ohms 
Conditions that exceed the absolute maximum stress limits may Conditions that exceed the operating limits may cause the device ta 
destroy the device. function incorrectly. 


Operating Conditions 


Symbol | Pins 


Supply voltage 









5.25 


- 4.75 


Static” - 


Vv 


mA 





Supply current 








Supply current Dynamic 






Ambient temperature 


* Static means: all inputs at V,., all outputs floating, and all 
bi-directional pins configured as inputs. 


Inputs 


Input high voltage 
Input low voltage Vie - s 


Input leakage current Non-SCsI 0<V<V 
4.75<V 
Hysteresis BSYI/, SELI/, - 
REQI/ACKI/, 
RSTI/ 


Input low leakage SCSI V.=05;0<V,$55 


DD 


£5.25 


pb 


Input high leakage SCSI Vi =2208V,,,$55 


Capacitance 5 - - 
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Outputs 


Output high voltage y DREQ.IGS, Lz 72 mA 
Output low voltage ’ DREQ, IGS, INT/ 1,= 4mA 
Output high voltage / RESTO 1274 mA 
Output low voltage RSTO/ SELO, \,= 48mA 

ATNO/, MSGO/, 

ACKO/, REQO/, 

SDOP/, BSYO/, 

C/D, 1/0, $DO7-0 


Hi Z state leakage - 0<V,4<\ 


/ 
Our DD 


Capacitance 


Bi-Directional Pins 


Input high voltage 
Input low voltage 


Output high voltage V SD17-0, DB15-0, 
DBPI1-0, PAD7-0 


Output low voltage SDI7-0, DBI5-0, 
DBP1-0, PAD7-0 

Output high voltage TGS 

Output low voltage Mey: TGS 

Input current, low TGS 

Input current, low SDI7-0 


Input current, low DBI5-0, DBPI-0, 
PAD7-0 

Input current, high DBI5-0. DBPI-0, 
PAD7-0, TGS 


Hi Z pull-up current DBI5-0, DBPI-0, 
PAD7-0 





Capacitance ; - 
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AC Electrical Characteristics 


The AC characteristics described herein apply over the 
voltage range V,,,= 4.75 -5.25 V and the temperature range 
0°-70°C. Chip output timing is based on simulation under 


Signal Name 


RESETO, DREQ, TGS, IGS, SDIP/, SDI7/-SD10/ 
DB7-0 

INT/ 

RSTO/, SELO/, BSYO/, ATNO/, MSGO/, CDO/ 
1OO/, REQO/, ACKO/, $D07-0/, SDOP 


System Interface 

All timings in this specification are taken from the 10% 
and 90% points with respect to the specified V., and V, 
of the waveforms. 


on 


Clock 


Clock period 

Clock frequency, asynchronous 
Clock frequency, synchronous 
Clock high 


Clock low 


Synchronization latency =t.,, + ts, 


These minimum numbers required to comply with ANSI SCSI 
specification. For synchronous SCSI data transfers, the clock 
mputs must also meet the following requirements: 


> 9792 ns 


2t..7 €,, 29792 ns and Qlopt boy? 


Ck “G6 = 


34 


worst case conditions (4.75 V. 70°C) and the following pad 
termination: 


Output Load 


30 pr 

85 pl 

50 pl, IK pull-up 

200 pl, 10 pullup, 165 pulldown 
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Am7990 ide 
Local Area Network Controller for Ethernet (LANCE) Devices 





DISTINCTIVE CHARACTERISTICS 


@ Compatible with Ethernet and IEEE-802.3 10Base5 @ Back-to-back packet reception with as little as 4.1 wsec 


Type A, and 10Base2 Type B, ‘‘Cheapernct'’) 
@ Easily interfaced to 8086, 68000, Z8000™, Lsi-11"M 
microprocessors 
@ On-board DMA and buffer management, 48 byte FIFO 
24-bit wide linear addressing (Bus Master Mode) 
@ Network and packet error reporting 





interpacket gap time 
@ Diagnostic Routines 
- Internal/external loop. back 
- CRC logic check 
- Time domain reflectometer 


GENERAL DESCRIPTION 


The Am7990 Local Area Network Controller for Ethernet 
(LANCE) is a 48-pin VLSI device designed to greatly 
simplify interfacing a microcomputer or minicomputer to an 
IEEE-802.3/Ethernet Local Area Network. The LANCE, in 
conjunction with the Am7992B Serial Interface Adapter 
(SIA), Am7996 Transceiver, and closely coupled local 


user with a complete interface module for an Ethernet 
network. The Am7990 is designed using a scaled N- 
Channel MOS technology and is compatible with a variety 
of microprocessors. On-board OMA, advanced buffer man- 
agement, and extensive error reporting and diagnostics 
facililate design and improve system performance. 


memory and microprocessor, is intended to provide the 
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TYPICAL ETHERNET/CHEAPERNET NODE 
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PIN DESCRIPTION 


DALgg-ODAL;5 Oata/Address Lines (Input/Output, 
Three-State) 

The time multiplexed Address/Data bus During the address 
portion of a memory transfer, DALgo - DAL 5 contains the 
lower 16 bits of the memory address. The upper 8 bits of 


address are contained in Ay6 - Ag3. 


Ouring the data portion of a memory transfer, 
DALgo - DAL15 contains the read or write data, depending 
on the type of transfer. 


The LANCE drives these lines as a Bus Master and as a Bus 
Slave. 


High Order Address Bus (Output Three- 
State) 

Additional address bits to access a 24-bit address. These 
lines are driven as a Bus Master only. 


READ (Input/Output, Three-State) 

Indicates the type of operation to be performed in the 
current bus cycle. This signal is an output when the LANCE 
is a Bus Master. 


High - Data is taken off the DAL by the LANCE. 
Low - Data is placed on the DAL by the LANCE. 

The signal is an input when the LANCE is a Bus Slave. 
High - Data is placed on the DAL by the LANCE. 
Low - Data is taken off the DAL by the LANCE. 


BMo/BYTE, BM;/BUSAKO (Output, Three-state) 
The two pins are programmable through bit (00) of CSR3. 


BMo, BM; — If CSR3 (00) BCON = 0 
PIN 15 = BMo (Output Three-state) (48-Pin DIPs) 
PIN 16 = BM, (Output Three-state) (48-Pin DIPs) 


BMo, BM; (Byte Mask). This indicates the byte(s) on the 
DAL are to be read or written during this bus transaction. 
The LANCE drives these lines only as a Bus Master. It 
ignores the Byte Mask lines when it is a Bus Slave and 
assumes word transfers. 


A16- A23 


Byte selection using Byte Mask is done as described by the 
following table. 


BM; BMo 


LOW LOW Whole Word 
LOW HIGH Upper Byte 
HIGH LOW Lower Byte 
HIGH HIGH None 


BYTE, BUSAKO — If CSR3 (00) BCON = 1 
PIN 15= BYTE (Output Three-state) (48-Pin DIPs) 
PIN 16 = BUSAKO (Output) (48-Pin DIPs) 


Byte selection may also be done using the BYTE line and 
DALoo line, latched during the address portion of the bus 
cycle. The LANCE drives BYTE only as a Bus Master and 


ignores it when a Bus Slave selection is done (similar to 
BMo, BM)). 





Byte selection is done as outlined in the following table. 


BYTE DAL oo 


LOW LOW Whole Word 
LOW HIGH illegal Condition 
HIGH LOW Lower Byte 
HIGH HIGH Upper Byte 


be driven LOW. If the LANCE is requesting the bus when ut 
receives HLDA, BUSAKO will remain HIGH 


Byte Swapping 


In order to be compatible with the variety of 16-bit 
microprocessors available to the designer, the LANCE may 
be programmed to swap the position of the upper and lower 
order bytes on data involved in transfers with the internal 
FIFO. 


Byte swapping is done when BSWP = 1. The most 
significant byte of the word in this case will appear on DAL 
lines 7-0 and the least significant byte on DAL lines 15-8. 


When BYTE =H (indicating a byte transfer) the table 
indicates on which part of the 16-bit data bus the actual data 
will appear. 


Whenever byte swap is activated, the only data that is 
swapped is data traveling to and from the FIFO. 


BSWP =0 BSWP =1 
Signal Line and BCON = 1] and BCON=1 


BYTE =L and 
WwW. 
BYTE =L and 
DALoo = H 
BYTE =H and 
{ 
BYTE =H and 


CS Chip Select (Input) 
Indicates, when asserted, that the LANCE is the slave 
device of the data transfer. CS must be valid throughout the 
data portion of the bus cycle. CS must not be asserted when 
FALDA is LOW. ; 


ADR Register Address Port Select (input) 
When LANCE is slave, ADR indicates which of the two 
register ports is selected. ADR LOW selects register data 
port; ADR HIGH selects register address port. ADR must be 
valid throughout the data portion of the bus cycle and is only 
used by the LANCE when CS is LOW. 


ALE/AS Address Latch Enable (Output, Three-State) 
Used to demultiplex the DAL lines and define the address 
portion of the bus cycle. This |/O pin is programmable 
through bit (01) of CSR3. 


As ALE (CSR3 (01), ACON = 0), the signal transitions from a 
HIGH to a LOW during the address portion of the transfer 
and remains LOW during the data portion. ALE can be used 
by a Slave device to control a latch on the bus address 
lines. When ALE is HIGH, the latch is open, and when ALE 
goes LOW, the latch is closed. 


As AS (CSR3 (01), ACON = 1), the signal pulses LOW 
during the address portion of the bus transaction. The LOW- 
to-HIGH transition of AS can be used by a Slave device to 
strobe the address into a register. 


The LANCE drives the ALE/AS line only as a Bus Master. 
DAS Data Strobe (Input/Output Three-State) 













Defines the data portion of the bus transaction. DAS is high 
during the address portion of a bus transaction and low 
during the data portion. The LOW-to-HIGH transition can be 


BUSAKO is a bus request daisy chain output. If the chip is 
not requesting the bus and it receives HLDA, BUSAKO will 
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used by a Slave device to strobe bus data into a register. 
DAS is driven only as a Bus Master. 


DALO  Data/Address Line Out (Output, Three-State) 
An external bus transceiver control line. DALO is asserted 
when the LANCE drives the DAL lines. DALO will be LOW 
only during the address portion if the transfer is a READ. It 
will be LOW for the entire transfer if the transfer is a WRITE. 
BALO is driven only when LANCE is a Bus Master. 


DALI Data/Address Line In (Output, Three-State) 
An external bus transceiver control line. DALI is asserted 
when the LANCE reads from the DAL lines. It will be LOW 
during the data portion of a READ transfer and remain HIGH 
for the entire transfer if it is a WRITE. DALI is driven only 
when LANCE is a Bus Master. 


HOLD/BUSRQ Bus Hold Request (Output, Open 
Drain) 

Asserted by the LANCE when il requires access to memory. 
HOLD is held LOW for the entire ensuing bus transaction. 
The function of this pin is programmed through bit (00) of 


CSA3. Bit (00) of CSR3 is cleared when RESET is asserted. 
When CSR3 (00) BCON =0 


PIN 17 = HOLD (Output Open Drain and input sense) (48- 
Pin DIPs) 


When CSR3 (00) BCON = 1 
PIN 17 = BUSRO (I/O Sense, Open Drain) (48-Pin DIPs) 


If the LANCE wants to use the bus, it looks at HOLD/ 
BUSRQ; if it is HIGH the LANCE can pull it LOW and 
request the bus. If it is already LOW, the LANCE waits for it 
to go inactive-HIGH before requesting the bus. 


HLDA Bus Hold Acknowledge (Input) 
A response to HOLD. When HLDA is LOW in response to 
the chip's assertion of HOLD, the chip is the Bus Master. 


During bus master operation the LANCE waits for HLDA to 
be deasserted ‘HIGH’ before reasserting HOLD ‘LOW’. This 
insures proper bus handshake under all situations. 


INTR Interrupt (Output Open Drain) 
An attention signal that indicates, when active, that one or 
more of the following CSRo status flags is set: BABL, 
MERR, MISS, RINT, TINT or IDON. INTR is enabled by bit 
06 of CSRo (INEA = 1). INTR remains asserted until the 
source of Interrupt is removed. 
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RX = Receive (Input) 
Receive Input Git Stream. 


TX Transmit (Output) 
Transmit Output Bit Stream. 


TENA = Transmit Enable (Output) 
Transmit Output Bit Stream enable. When asserted, it 
enables valid transniit output (TX). 


RCLK Receive Clock (input) 
A 10-MHz square wave synchronized to the Receive data 
and only active while receiving an Input Bit Stream. 


CLSN- Collision (input) 
A logical input that indicates that a collision is occurring on 
the channel. 


RENA_ Receive Enable (input) 
A logical input that indicates the presence of carrier on the 
channel. 


TCLK Transmit Clock (input) 
10-MHz clock. 


READY (Input/Output, Open Drain) 
When the LANCE is a Bus Master, READY is an 
asynchronous acknowledgement from the bus memory that 
it will accept data in a WRITE cycle or that it has put data on 
the DAL lines in a READ cycle. 


As a Bus Slave, the LANCE asserts READY when it has put 
data on the DAL lines during a READ cycle or is about to 
take data off the DAL lines during a write cycle. READY is a 
response to DAS and will return High after DAS has gone 
High. READY is an input when the LANCE is a Bus Master 
and an output when the LANCE is a Bus Slave. 


RESET Reset (Input) 
Bus Request Signal. Causes the LANCE to cease operation, 
clear its internal logic, and enter an Idle state with the stop 
bit of CSRo set. It is recommended that a 3.3 kQ pullup 
tegister be connected to this pin. 


Vcc Power supply pin +5 volts +5%. 
It is recommended that a 0.1-uF and a 10-yF decoupling 
Capacitor be used between Vcc and Vss. 


Vss Ground. 
Pin 1 and 24 (48-Pin DIPs) should be connected togethe 
externally, as close to the chip as possible. . 





PROGRAMMING 


This section defines the control and Status Registers and the 
memory data structures required to program the Am7990 
(LANCE). 


Programming the Am7990 (LANCE) 


The Am7990 (LANCE) is designed to operate in an environ- 
ment that includes close coupling with a local memory and a 
microprocessor (HOST). The Am7990 LANCE is programmed 
by a combination of registers and data structures resident 
within the LANCE and in memory. There are four Control and 
Status Registers (CSRs) within the LANCE which are pro- 
grammed by the HOST device. Once enabled, the LANCE has 
the ability to access memory locations to acquire additional 
operating parameters. 


The Am7990 has the ability to do independent buffer manage- 
ment as well as transfer data packets to and from the Ethernet. 
There are three memory structures accessed by the Chip: 


1. Initialization Block - 12 words in contiguous memory starting 
on a word boundary. It also contains the operating parame- 
ters necessary for device operation. The initialization block 
is comprised of: 


® Mode of Operation 

@ Physical Address 

®@ Logical Address Mask 

@ Location to Receive and Transmit Descriptor Rings 

@ Number of Entries in Receive and Transmit 
Descriptor Rings 


2. Receive and Transmit Descriptor Rings - Two ring struc- 
tures, one each for incoming and outgoing packets. Each 
entry in the rings is 4 words long and each entry must start 
on a quadword boundary. The Descriptor Rings are com- 
prised of: 


@ The address of a data buffer 
@ The length of that data buffer 
@ Status information associated with the buffer 


3. Data Buffers - Contiguous portions of memory reserved for 
packet buffering. Data buffers may begin on arbitrary byte 
boundaries. 


In general, the programming sequence of the LANCE may be 
summarized as: 


1. Programming the LANCE's CSRs by a host device to locate an 
initialization block in memory. The byte control, byte addressing, 
and address latch enable modes are defined here also. 


2. The LANCE loading itself with the information contained 
within the initialization block. 


3. The LANCE accessing the descriptor rings for packet 
handling. 


Control and Status Registers 


There are four Control and Status Registers (CSRs) resident 
within the chip. The CSRs are accessed through two bus 
addressable ports, an address port (RAP) and a data port 
(RDP). 


Accessing the Control and Status Registers 


The CSRs are read (or written) in a two step operation. The 
address of the CSR to be accessed is written into the address 
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port (RAP) during a bus slave transaction. During a subse- 
quent bus slave transaction, the dala being read from (or 
written into) the data port (RDP) 1s read from (or written into) 
the CSR selected in the RAP. 


Once written, the address in RAP remains unchanged until 
rewritten. 


To distinguish the data port from the address port, a discrete 
1/O pin is provided. 
ADR 1/0 Pin Port 


L Register Data Port (RDP) 
H Register Address Port (RAP) 





Register Data Port (ROP) 


15 0 
AF001450 
Bit Name Description 





15:00 CSR Data Writing data into RDP writes the 
data into the CSR selected in 
RAP. Reading the data from the 
RDP reads the data from the CSR 
selected in RAP. CSR;, CSR 
and CSR3 are accessible only 
when the STOP bit of CSRo is 


set. 


lf the STOP bit is not set while 
attempting to access CSR}, 
CSR2 or CSR3, the LANCE will 
return READY, but a READ 
operation will return undefined 
data. WRITE operation is ignored. 


Register Address Port (RAP) 


ee 


Se Se a ee I ee 
| L CSR 1:0 
RES 
AFO01490 
Bit Name 
15:02 RES 
01:00 CSR(1:0) 


Description 





Reserved and read as zeroes. 


CSR address select. READ/ 
WRITE. Selects the CSR to be 
accessed through the RDP. RAP 
is cleared by Bus RESET. 


CSR(1:0) CSR 
00 CSRo 
01 CSR, 
10 CSRo2 
11 CSR3 


1-17 


wwe = = ee ew wi ae 7 oie . —_— ——_—= _— me be me = 


a 
wee & DSA) McpraRe ee yer H28% pi Wel ET MAIO OES 

Wi bY crepe faint! ha 1 te en - ; 

(Git * jhe ods tapi) Saot sa pA & 2 © Le sare tailbw PDN a eo a Gt Penk Ah eat Ds aN” ay, aulh 
; Be EA py Oo Palos AZO yop. Vere e* Wah Arespory me” ‘eh al Hoe mi) meity qicth om 


a - : Mae 

Tite: BAGH, Zhe wie © HP qr epyh ~- yornay ¢ Sts = Oe : 7 oN 
: ’ 4 rehwuse Me pe eure) J) Gash ir. a git tplca ree, & Teor *\) 
72 ONG We. i Ola ead o) > ap Fe a CAAT OO FA eit 


‘ 


Bates freq fee vis Wee Wak 8, fee ly bAsoday it { 
BU Va HW AIS Se) a eee Spe 











-¥ we ‘+ 
- a =e aie heures © = ay aon 5 OSE TawA ant iTect) LOSE Sve ATID 
: d 4 “$4 O81 WOR ASS! peiolouite Bley ihe FEST 31 Ip sie hed imial 784 
et ti eet ail Ameren ae alee oe! hem ake eaten «| HORS! has Oph oak 2? sete oe tot LR Ger rl > 
> TICS, ho? ete Nb eM 4 2 4 aye. a tw Ate > 9 Ue Nae (eM ABs Gr a: OS 
eA) ha gow 4 % ba Bail S08 7 oa basiacsd oC aitweih Rhea! 7A te te : 
: fe (of &— He Wt PPM pea OF whe wie web  % it 
“i 4 od atath yolalgult : tliat te 
EE Meg fae AS OL Gd Me ke Sp Meg 
7 7 MENS wr} sa oR f= Oe, 07 “WEAN 45 lho vay are 
nn — - lime oh ont ———— 7 re wi’ @? Ukae ante uur 2 @e* ay. 
1 ee eee _ - - Se ae a i {i Ale (eS =~» Crippl aD ie Ot ash G iota o 
bab rides : ne 5G Ot ls wae a eee Se tz TETAS) Da) SOG ¥ 
Stahl fae ree ares “naer) bs Gales ve vingsdowl =e 
(ley pada) met be by hoarse es a 7 
er ee ee es ee Sa ae ed me | 
fd (the VGH ni Blab vite’ in Wo) iS Bag ry 4 
“ Eslomles ct are Sly #/s OPH tHe Re? : 
SH ll BLA AT Ore FFF bee =. 4'G,7e535,% 
AST -gre il Maa ort Lee. 5h e~ == ey, ’ rigs? sm A ~5ue 1 sie 
120 R85 SAR bilge tt ) 3, ME 8 AF ty ate OH & te 
wee Sid@svasse vis Noo er ® iyo 
og GS ta td SOPs ant aii Ye al ye “MNS het Che Gols” oe = 
iY ot ee ao] Sh ay” 2 bey SD) Sal 
aifia tee Sr Bi OY MITE »- REIS Th. oer gee a ee PP ye 
aE° iweus «=! @7 ar Mae Te a PR, > > +1 pi? » Talihea WS 


Hige Walls 2 A GET iy rts) 4 ett YY 


S855. = oH .YORD Su) 
Corie py “Ae 14 aeeto7 


ra é o,) o ety | A 
Gove, ! tothe = a ; 
’ itt unl © aap oy ied oh cee lle ine @ oe 
x 
= Met o) goes = + ie jor ~, = » Sint Sy 
“nx - = A 
peer + i fame8 ' Pal eee’ tal » * ee Safes oi oul 
, ee 1 
7 Se — —r - 
| ry gat nj 4 perv,T af 5 0 
——— L.. — - — ed Sie TY iI 
Ji aes vise: ) a oo Ts : , a oe, 
aps ve > » a ~ 
ied 
8 : 10" eAT yp? oe : g ‘ 
i — Cine se 7 a 
Wl d, sk Oy q WS. SA Os : ake 
c at ie 
= tice = hehS on? Wr ft) 4 eo <P) hes" ~ ev 3 
en ns = LE ip quite Srp te 
‘ a Ne oe wen ~s 
He O35. Fa o6ui Orn ‘ ne indians “ ‘gM ote 5 aa apne tAAs ose 
LA 8s 2an oi? te? a) : Afiengs? 
i "> any, v-ew ' 4 bo Rated sailors gS Ovens 
me Sd 2 oy * ary ; 
ONES 25 yl oO 9 : “Tal = Mi afm §) ie oy § eh 
' i “Tek j i «8 &\ a 7 Mihas 
' 
1% Patty SSL, vA e te >. a4 .°2 6] = @t)¥Aaaite 
o> 
Mi 3 
Ly i 
: Licigeh i= Patt . ie m*. MOIASS aS- 
- f ' aovt Gus w! ‘ i. yh oh 
7 ¥ e em 7 ry oe ev, id = 
) 
sa 
~ - ~\ 





ci 


Am7992B voeaillats 
Serial Interface Adapter (SIA) Devices 





DISTINCTIVE CHARACTERISTICS 


e Compatible with Ethernet/Cheapernet/IEEE-802.3 
specifications 

@ Crystal/TTL oscillator controlled Manchester Encoder 

@ Manchester Decoder acquires clock and data within four 
bit times with an accuracy of !3 ns 

e@ Guaranteed carrier and collision detection squelch 
threshold limits 
- Carrier/collision detected for inputs greater than 

-275 mV 

- No carrier/collision for inputs less than -175 mV 


© Input signal conditioning rejects transient noise 
- Transients < 10 ns for collision detector inputs 
- Transients < 20 ns for carrier detector inputs 

e Receiver decodes Manchester data with worst case 
419 ns of clock jitler (at 10 MHz) 

e@ TTL compatible host interface 

@ Transmit accuracy !0.01% (without adjustments) 


nnn 


GENERAL DESCRIPTION 


The Am7992B Serial Interface Adapter (SIA) is a Manches- 
ter Encoder/Decoder compatible with IEEE-802.3, Cheap- 
ernet and Ethernet specifications. In an IEEE-802.3/Ether- 
net application, the Am7992B interfaces the Am7990 Local 
Area Network Controller for Ethernet (LANCE) to the 
Ethernet transceiver cable, acquires clock and data within 


four bit times, and decodes Manchester data with worst 
case 419 ns phase jitter at 10 MHz. SIA provides both 
guaranteed signal threshold limits and transient noise 
suppression circuitry in both data and collision paths to 
minimize false start conditions. 





BLOCK DIAGRAM 
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RELATED PRODUCTS 


Description 


Am7990 Local Area Network Controller for Ethernet (LANCE) 


Am7996 |EEE-802.3/Ethernet/Cheapernet/Transceiver 
Am79C900 | Integrated Local Area Communications Controller (ILACC) 


Pudlicaions 03378 Rev. G Amondmanto 


Issue Data June 1990 
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PIN DESCRIPTION 


CLSN-~ Collision (Output, TTL Active HIGH) 

Signals at the Collision +terminals meeting threshold and 
pulse width requirements will produce a logic HIGH at 
CLSN output. When no signal is present at Collisiont, 
CLSN output will be LOW. 


RX Receive Data (Output) 

A MOS/TTL output, recovered data. When there is no 
signal at Receivet and TEST is HIGH, RX is HIGH. RX is 
actuated with RCLK and remains active until RENA is de- 
asserted at the end of message. During reception, RX is 
synchronous with RCLK and changes after the rising edge 
of RCLK. When TEST is LOW, RX is enabled. 


RENA_ Receive Enable (Output, TTL Active HIGH) 
When there is no signal at Receivet RENA is LOW. 
Signals meeting threshold and pulse width ‘'on'' 
requirements will produce a logic HIGH at RENA. When 
RENA is HIGH, Receivet signals meeting threshold and 
pulse width "'off'' requirements will produce a LOW at 
RENA. 


RCLK Receive Clock (Output) 

A MOS/TTL output, recovered clock. When there is no 
signal at Receivet and TEST is HIGH, RCLK is LOW. 
RCLK is activated 1/4 bit time after the second negative 
Manchester preamble clock transition at Receivet, and 
remains active until end of message. When test is LOW, 
RCLK is enabled and meets minimum pulse width 
specifications. 


TX Transmit (Input) 
TTL-compatible input. When TENA is HIGH, signals at TX 
meeting setup and hold time to TCLK will be encoded as 
normal Manchester at Transmit+ and Transmit-. 
TX HIGH: Transmit+ is negative with respect to 
Transmit- for first half of data bit cell. 
TX LOW: Transmit+ is positive with respect to 
Transmit- for first half of data bit cell. 


TENA Transmit Enable (input) 

TTL-compatible input. Active HIGH data encoder enable. 
Signals meeting setup and hold time to TCLK will allow 
encoding of Manchester data from TX to Transmit+ and 
Transmit-. 


TCLK Transmit Clock (Output) 

MOS/TTL output. TCLK provides symmetrical HIGH and 
LOW clock signals at data rate for reference timing of data 
to be encoded. It also provides clock signals for the 
controller chip (Am7990 - LANCE) and an internal timing 
reference for receive path voltage controlled oscillators. 


Transmit+ Transmit (Outputs) 

Transmit- : 

A differential line output. This line pair is intended to 
operate into terminated transmission lines. For signals 
meeting setup and hold time to TCLK at TENA and TX, 
Manchester clock and data are outputted at Transmit+ / 
Transmit-. When operating into a 78 92 terminated 
transmission line, signaling meets the required output 
levels and skew for both Ethernet and IEEE-802.3 drop 
cables. 


Receive+ Receiver (Inputs) 

Receive— 

A differential input. A pair of internally biased line receivers 
consisting of a carrier detect receiver with offset threshold 
and noise filtering to detect the line activity, and a data 
recovery receiver with no offset for Manchester data 
decoding. ; 

Collision+ Collision (Inputs) 

Collision- 

A differential input. An internally biased line receiver input 
with offset threshold and noise filtering. Signals at 
Collisiont have no effect on data-path functions. 


TSEL Transmit Mode Select (Output, Open 
Collector; Input, Sense Amplifier) 
TSEL LOW: Idle transmit state Transmit+ is positive 
with respect to Transmit-. 
TSEL HIGH: Idle transmit state Transmit+ and Transmit- 
are equal, providing “zero” differential to 
operate transformer coupled loads. 


When connected with an RC network, TSEL is held LOW 
during transmission. At the end of transmission the open 
collector output is disabled, allowing TSEL to rise and 
provide a smooth transmission from logic HIGH to ‘'zero"' 
differential idle. Delay and output return to zero are 
externally controlled by the RC network at TSEL and 
Transmitt load inductance. 


X1, X2 Biased Crystal Oscillator (input) 

Xj, is the input and XQ is the bypass port. When connected 
for crystal operation, the system clock which appears at 
TCLK is half the frequency of the crystal oscillator. X; may 
be driven from an external source of two times the data 
rate. 


RF Frequency Setting Voltage Controlled 
Oscillator (Vco) Loop Filter (Output) 

This loop filter output is a reference voltage for th> receive 

path phase detector. It also is a reference fc* timing noise 

immunity circuits in the collision and receive enable path. 

Nominal reference Vco gain is 1.25 TCLK frequency 

MHz/V. as 

PF Receive Path Vco Phase-Lock Loop Filter (input) 

This loop filter input is the control for receive path loop 

damping. Frequency of the receive Vco is internally limited 

to transmit frequency +12%. Nominal receive Vco gain is 

0.25 reference Vco gain MHz/V. 

TEST Test Control (input) 

A static input that is connected to Voc for Am7992B/ 

Am7990 operation and to Ground for testing of Receive+ 

path threshold and RCLK output high parameters. When 

TEST is grounded, RX is enabled and RCLK is enabled 

except during Clock acquisition when RCLK is HIGH. 

GND; High Current Ground 

GND2 ~~ Logic Ground 

GND3 Voltage Controlled Oscillator Ground 

Vec1 High Current and Logic Supply 


Vcc2 Voltage Controlled Oscillator Supply 
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FUNCTIONAL DESCRIPTION path. In addition, the SIA provides the interface between the 
TTL logic environment of the Local Area Network Controller 
: i ial si ling environ- 

The Am7992B Serial Interface Adapter (SIA) has three basic for Ethernet (LANCE) and the differential signaling 


functions. It is a Manchester Encoder/line driver in the ment in the transceiver cable. 


transmit path, a Manchester Decoder with noise filtering and 
quick lock-on characteristics in the receive path, and a signal 
detect/converter (10 MHz differential to TTL) in the collision 
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pESCRIPTION 
ong is a family of 4194304-word by 1-bit dynamic RAMs, 


.,sricated with the high performance CMOS process, and 
© Ae for large-capacity memory systems where high 
ae low power dissipation, and low costs are essential. 
ij use of quadruple-layer polysilicon process combined 
aah silicide technology and a single-transistor dynamic 
sorage stacked capacitor cell provide high circuit density 
y: reduced costs. Multiplexed address inputs permit both 
; eduction in pins and an increase in system densities. 


FEATURES 





Cycle 
time 















RAS CAS Address 
access 
time 


(nix. as) 
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15M44100 7 8 
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| womesro0z 10 
¢ Standard 26 pin SOJ, 20 pin ZIP 
e Single 5V+10% supply 

¢ Low standby power dissipation 


SSW Mad) sss aces, ase ea ces CMOS Input level 
@ Low operating power dissipation 

M5M44100J,L-8 .. 2.2... 2... 522.5mW (Max) 

MSM44 1005, L710) 205 cee cao 467.5mW (Max) 


¢ Fast-page mode (2048 bits random access), Read-modify- 
write, RAS-only refresh, CAS before RAS refresh, 


Hidden refresh capabilities 


® Early-write operation gives common I/O capability 

* All inputs, output TTL compatible and low capacitance 
* 1024 refresh cycles every 16.4ms (Ap~Ag) 

° 512K word x 8 bit test mode capability 
APPLICATION 


“fain memory unit for computers, Microcomputer memory, 
?efresh memory for CRT 


MSM44100/,L-8, -10 


FAST PAGE MODE 4194304-BIT(4194304-WORD BY 1-BIT) DYNAMIC RAM 
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PIN CONFIGURATION (TOP VIEW) 


DATA INPUT 1) Ves (OV) 


WRITE CONTROL Zz Aa) 
INPUT 


ROW ADORLSS RAS -- 
STROBE INPUT 


NO CONNECTION NC 


DATA OUTPUT 


THE COLUMN anDaE55 
A STROBE INPUT 


NC NO CONNECTION 


ADDRESS 
INPUTS 
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ADORESS INPUT Ag -+ ———= COLUMN ADDRESS 


CAS strope input 


(ov) 


WRITE CONTROL 
INPUT 


ADDRESS INPUT 


DATA OUTPUT O-« 
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rn NO CONNECTION 

ADDRESS inputs J ° 
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MS5M44100J, L-8, - 19 





FAST PAGE MODE 4194304-BIT(4194304-WORD BY 1-BIT) DYNAMIC Ray: 


FUNCTION 

The M5M44100J, L provide, in addition to normal read, 
write, and read-modify-write operations, a number of 
other functions, e.g., fast-page mode, RAS-only refresh, 
and delayed-write. The input conditions for each are shown 
in Table 1. 


Table 1 Input conditions for each mode 


Inputs 
Operation 


Write (Early write) Fast page mode a 
Standby 


Note ACT active, NAC nonactive, DNC don‘tcare, VLD valid, 1VD: invalid, APD: applied, OPN: open ks 


ONC 
ONC 
ONC 





BLOCK DIAGRAM 
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Am79 C30A/32A | Advanced 











Digital Subscriber Controller (DSC) Micro 
ISDN Data Controller (IDC) Devices 
DISTINCTIVE CHARACTERISTICS 
™ Combines CCITT 1.430 S/T Interface trans- CRC generation/checking 
celver, D-channel LAPD processor, and audio Zero insertion/deletion 
processor (DSC only) In a single chip Four 2-byte address detectors 
Random number generation 
Interrupt-driven microprocessor Interface 8-byte transmit and receive FIFOs 
CMOS technology, TTL compatible = Audio Processing Capability (DSC only) 
*S’ or ‘T’ Interface Transcelver ‘Dual audio inputs 
Level 1 Physical Layer Controller ¢ BF  ecnaht e tiaie a 
Supports point-to-point, short or extended ‘ne 
passive bus configurations te tere rn cata 
chalet Programmable DTMF, single tone, and ringer 
@ D-channel Processing Capabllity tone generation 
Flag generation/detection 
BLOCK DIAGRAM 
CAP, CAP, 
AINA__,+ 
“RIN LOUT, 
EAR, LOUT, 
ts Am79C30A O re Ln, 
i ou nly) Po LIN, 
XTAL,___* DLC ‘ 
ie ee : 
en 3 
MCLK <—! i 
CS! 
Wa ; ; 
BD : RESET 
nee eee See 2S 8 ee eee SE eee ; 


LIU Line Interface Unit 

MUX Multiplexer 

MAP Main Audio Processor 7 + + + Do INT Ae Ar Ao 
DLC Data Link Controller 

MPI _— Microprocessor Interface 


OSC Oscillator and Timing Circuit 
Publication# 09893  Rev.D Amendment /0 
Issue Date: March 1989 


1-1 





GENERAL DESCRIPTION 


The Am79C30A Digital Subscriber Controller (DSC) 
and Am79C32A ISDN Data Controller (IDC), shown in 
the block diagram, provide the Terminal Equipment ac- 
cess to the ISDN. The Am79C30A/32A is compatible 
with the CCITT I-Series recommendations at the ‘S' ref- 
erence point allowing the user of the device to design 
TEs which conform to the international ISDN standards. 


The Am79C30A/32A provides a 192 kbps full duplex 
digital path between the TE located in the subscriber's 
premises and the NT or PABX line card over 4-wires. 
The Am79C30A/32A separates the bit stream into the 
B1- (64 kbps), B2- (64 kbps) and D- (16 kbps) channels. 
The B-channels are routed to different sections of the 
Am79C30A under user control. The D-channel is par- 
tially processed in the Am79C30A/32A and passed to 
the microprocessor for further processing. 


The transmission rate of 192 kbps provides a 48-bit 
frame every 250 us for framing and maintenance. The 
frame structure provides for frame synchronization and 
multiple terminal contention resolution as described in 
the CCITT I-series recommendations. Both point-to- 
point and point-to-multipoint connections are 
supported. 


The Am79C30A can be used as a voice telephone, a 
digital data terminal, or a voice and data terminal. The 
Am79C32A can be used as a digital data terminal. 


The audio processor in the Am79C30A, shown in the 
block diagram, uses Digital Signal Processing (DSP) to 
implement the codec and filter functions. The audio 
processor interfaces to a speaker, an earpiece, and two 
separate audio inputs. Inthe receive and transmit paths 
the user may program gain or alter the frequency re- 
sponse. The audio processor is not available in the 
Am79C32A. 


A serial port gives the user access to the B-channels of 
the Am79C30A/32A multiplexer. This serial port may be 
used by data terminals and provides, with additional cir- 
cuitry, access to the CCITT ‘R' reference point. 


The Am79C30A/32A is controlled via an interrupt driven 
microprocessor bus interface by an external micropro- 
cessor. Using this interface, the microprocessor pro— 
cesses the D-channel information and programs the 
Am79C30A/32A accordingly. This includes program- 
ming a multiplexer within the Am79C30A/32A to route 
the B-channels as specified by the D-channel control in- 
formation. The microprocessor can interrogate and pro- 
gram the Am79C30A/32A via its mode, status, and error 
registers. 
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CONNECTION DIAGRAMS 
Top View 
40 Pin Dual-in-Line Package 
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Figure 2. Am79C30A DSC Connection Diagrams 
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PIN DESCRIPTION 


All signal levels are TTL compatible unless otherwise stated. 





Line Interface Unit (LIU) 


HSW . 
Hook-Switch (Input) 


The HSW signal indicates if the hookswitch is on or off 
hook. This signal may be generated with a mechanical 
switch wired to ground with a pull-up resistor to Vcc. Any 
change in the HSW state causes an interrupt. 


LIN1, LIN2 
Subscriber Line Input (Differential Inputs) 


The LIN1 and LIN2 inputs interface to the subscriber (‘S’ 
reference point) via an isolation transformer. LIN2 is the 
positive input, LIN1 isthe negative input. These pins are 
not TTL compatible. 


LOUT1, LOUT2 
Subscriber Line Output (Differential Outputs) 


The LOUT1 and LOUT2 line driver output signals inter- 
. face to the subscriber line at the ‘S’ reference point via 
an isolation transformer and resistors. LOUT2 is the 
positive ‘S’ interface driver (that is, sources current dur- 
ing a high mark) and LOUT1 is the negative ‘S' interface 
driver (that is, sources current during low mark). For 
muttipoint applications, all TE’s must maintain the same 
polarity on the ‘S' interface. These pins are not TTL 
compatible. 


Multiplexer (MUX) 


SBIN 
Serial Channel (Input) 


The data rate on SBIN is 192 kbps. SBIN consists of 
three 64 kbps serial channels. Data bytes are received 
MSB first. 


SBOUT 
Serial Channel (Output) 


The data rate on SBOUT is 192 kbps. SBOUT consists 


of three 64 kbps serial channels. Data bytes are trans- 
mitted MSB first. 


SCLK 
Serial Clock (Output) 


SCLK is a 192 kbps synchronization clock which defines 
the position of the serial bits in the SBOUT and SBIN 
channels. Data at the SBIN input must be valid on the 
rising edge of SCLK. The data on the SBOUT pin 
changes on the falling edge of SCLK. SCLK powers up 
tri-stated, and is enabled when a MUX connection is 
programmed. 


SFS 
Serial Channel Frame Sync. (Output) 


SFS is an 8 kHz signal which identifies the beginning of 
each frame by alow to high transition. The192 kbps data 
stream on SBIN and SBOUT is referenced to SFS. SFS 


powers up tri-stated, and is enabled when a MUX con- 
nection is programmed. 


Main Audio Processor (MAP) 


All MAP pins are analog, and hence not TTL compatible ; 


AINA, AINB 
Analog (Inputs) 


These analog inputs allow for two separate analog 
(audio) inputs to the transmit path of the codec/ fitter. In- 
put signals on either of these pins must be referenced to 
AREF. 


AREF 
Analog Reference (Output) 


This is a nominal 2.4 V reference voltage output for bias- 
ing the analog inputs. Note that AREF is only available 
when the MAP is active. 


CAP1, CAP2 

Capacitor/Resistor (CAP1, input; CAP2, Output) 
An extemal resistor and capacitor are connected in - 
series between these pins. These components are 


needed for the integrator in the Analog to Digital 
Converter (ADC). 


EAR1, EAR2 
Earplece Interface (Differential Outputs) 
EAR1 and EAR2 are the outputs fromthe receive path of 


the filter codec. These differential outputs can directly 
drive 600 ohms. 


LS1,LS2 
Loudspeaker Interface (Differe..tlal Outputs) 


LS1 and LS2 are push-pull outputs which can directly 
drive a 50 ohm loudspeaker. 


Microprocessor Interface (MPI) 
A2-A0 
Address Line (Inputs) 


A2, Al, and AO signals select source and destination 
registers for read and write operations on the data bus. 


Gs ‘ 
Chip Select (input) 
GS must be low to read or write to the Am79C30A/32A. 


Data transfer occurs over the bidirectional data lines 
(D7-D0). 


D7-D0 

Data Bus (Bidirectional with High Impedance State) 
The eight bidirectional data bus lines are used to. ex- 
change information with the microprocessor. D0 is the 
least significant bit (LSB) and 07 is the most signifi 

bit (MSB). A high on the data bus line corresponds. - 
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logic ‘1° and low corresponds to a logic ‘0’. These lines 
act as inputs when both WR and CS are active and as 
outputs when both RD and CS are active. When CS is 
inactive or both RD and WR are inactive, the D0-D7 pins 
are in a high impedance state. 


INT 
Interrupt (Output) 


An active low output on the INT pin informs the external 
microprocessor that the Am79C30A/32A needs inter- 
rupt service. INT is updated once every 125 us. The INT 
pin remains active until the Interrupt Register (IR) is 
read or the Am79C30A/32A is reset. 


RESET 
Reset (Input) 


Reset is an active high signal which causes the 
Am79C30A/32A to immediately terminate its present 
activity and initialize to the reset condition. When reset 
returns low, the Am79C30A/32A enters the idle mode. 


RD 
Read (Input) 


The active low read signal is conditioned by CS and indi- 
cates that internal information is to be transferred onto 
the data bus. A number of internal registers are user ac- 
cessible. The contents of the accessed register are 
transferred onto the data bus after the high to low transi- 
tion of the RD input. 


WR 

~ Write (Input) 

The active lowwrite signal is conditioned by CS and indi- 
cates that external information on the data bus is to be 
transferred to an internal register. The contents of the 
data bus are loaded on the low to high transition of the 
WR input. 





Oscillator (OSC) 


MCLK 

Master Clock (Output) 

The MCLK output is available for use as the system 
clock for the ‘microprocessor. It is derived from the 
12.288 MHz crystal via a programmable divider in the 
Am79C30A/32A which provides the following MCLK 
output frequencies: 12.288, 6.144, 4.096, and 3.072 
MHz. 


XTAL1, XTAL2 
External Crystal (Output/Input) 


XTAL1 and XTAL2 are connected to an external parallel 
resonant crystal for the on-chip oscillator. XTAL2 can 
also be connected to an external source instead of a 
crystal, in which case XTAL1 should be left discon- 
nected. The frequency must be 12.288 MHz, + 80 ppm. 


Power Supply Pins 


AVcc 
AVss_ Analog ground (PLCC only) 
DVss__ Digital ground (PLCC only) 
DVcc +5V digital power supply, +5% (PLCC only) 


+5V analog power supply +5% (PLCC only) 


DIP Packages 
Vcc  +5V power supply, +5% (DIP only) 
Vss_ Ground (DIP only) 


Note: For best performance, decoupling capacitors should be 
installed between Vcc and Vss as close to the chip as 
possible. Do not use separate supplies for analog and digital 
power and ground connections. 
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OPERATIONAL DESCRIPTION 


In order to specify the functions of the Am79C30A/32A, MPI —- Microprocessor Interface 
the device has been divided into blocks as shown in the OSC Oscillator and Timing Circuitry 
block diagram. Each of the blocks listed below is defined 


separately in the Functional Description. User Accessible Reglsters/Buffers 

Llu Line Interface Unit : The microprocessor interface is used to program and 
MUX Multiplexer control the operation of the Am79C30A/32A. The follow- 
MAP Main Audio Processor (AM79C30A only). ing registers/buffers are user accessible in each of the 
DLC Data Link Controller blocks listed above and are described in the respective 


Functional Description Sections. 





Registers No. Mnemonic 





Line Interface Unit (LIU) 








LIU Status Register 1 LSR 
LIU Priority Register 1 LPR 
LIU Mode Registers 2 LMR 
Muhtiframe Register 1 MF 
Muttiframe S-Bit/Status Buffer 1 MFSB 
Multiframe Q-Bit Buffer 1 MFOB 
Multiplexer (MUX) 

MUX Control Registers 4 MCR 
Main Audio Processor (MAP) 

(Am79C30A only) 

X Filter Coefficient Registers 16 xX 

R Filter Coefficient Registers 16 . R 

GX Gain Coetficient Registers 2 GX 


GR Gain Coefficient Registers ~ 2 

GER Gain Coefficient Registers 2 

Sidetone Gain Coefficient Registers ba 2 

Frequency Tone Generator Registers ===... ws. 2 FTGR 
Amplitude Tone Generator Registers oe 242 ticle 

MAP Mode Registers 2 


Data Link Controller (DLC) 


First Received Byte Address Registers 4 FRAR 
Second Recsived Byte Address Registers 4 SRAR 
Transmit Address Register (16 bit) : 1 TAR 
D-channel Receive Byte Limit Register (16 bit) 1 DRLR 
D-channel Receive Byte Count Register (16 bit) (2 byte FIFO) 1 DRCR 
D-channel Transmit Byte Count Register (16 bit) 1 DTCR 
Random Number Generator Registers 2 RNGR 
D-channel Mode Registers 4 OMR 
D-channel Status Registers : 2 OSR 
Address Status Register (2 byte FIFO) 1 ASR 
D-channel Error Register (2 byte FIFO) 1 DER 


ssc aan nests 


Microprocessor Interface (MPI) 


Initialization Register 1 INIT 
Command Register 1 CR 
Interrupt Register 1 IR 

Data Register ‘ 1 DR 
D-channel Transmit Buffer (8 byte FIFO) 1 DCTB 
D-channel Receive Buffer (8 byte FIFO) | DCRB ° 
Bb Transmit Buffer 1 BBTB 

Bb Receive Buffer 1 BBRB 

Bc Transmit Buffer 1 BCTB 

Bc Receive Buffer 1 BCRB 


Note: See the Microprocessor Interface section for register addressing. 
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tnitializatlon 


The initialization procedure is controlled via the Initiali- 
zation Register (INIT) which is accessed by the micro- 
processor as defined in the Microprocessor Interface 


Initlalizatlon Register (INIT), Read/Write 


section. This Initialization Register (INIT) has the follow- 
ing format: 




















Bit # 4 
76543210 Control Function 
xxXX XX X00 Power Mode Selection Idle Mode (defauh) 
Xx XX XXXO01 Active Mode (voice & data) 
x XExXqax X X 1 O Active Mode (Data only) 
Xx XX XXX11 Reserved 
X XUKHX X oO X X Interrupt Selection Enable INT pin (default) 
X KKK X 1K X Disable INT pin 
XX 05.0.0 XXX Divide by 2 (default) 
X X¥ 001 X X X Clock Divider Selection Divide by 1 
Xx X01 0 X X X Divide by 4 
bP, a Nee Pai > a> ae Divide by 2 
Xt .0 0 x x & Divide by 3 
OR OT OX eX Divide by 2 
xX X110X% xX xX Divide by 2 
XM 111 XR X Divide by 2 
XU KX X X XXK Abort Selection Receive abort 
X 0X X X X X X No Receive abort (default) 
1X XX X X X X Transmit abort 
Oo X X X X XK X X No Transmit abort (default) 
Reset 


The Am79C30A/32A can be reset by driving the reset 
pin high. When power is first supplied to the 
Am79C30A/32A, a reset must be asserted. This 


Idle Mode Operation 


To conserve power the Am79C30A/32A can be placed 
in the idle mode. This can be done by either asserting 
the RESET signal or by clearing bits 0 and 1 in the INIT 


initializes the Am79C30A/32A to its default values as 
defined in the subsequent sections. After reset, the 
Am79C30A/32A enters the idle mode. 


register. When the Am79C30A/32< is in the idle mode, 
and there is no activity on any of the external interfaces, 
the state of the output pins are: 


Pin Name. State following RESET Idie Mode 

a 

D7-Do High impedance High impedance 

MCLK 6.144 MHz As programmed (see Initialization section) 

INT Logical ‘1° Logical ‘1’ can be driven low by interna! conditions 
explained below 

SBOUT High impedance High impedance 

SFS High impedance 8 kHz 

SCLK High impedance 192 kHz period 

LS1, LS2 

EAR1, High impedance High impedance 

EAR2, 

AREF 

LOUT1, High impedance High impedance 

LOUT2 
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FUNCTIONAL DESCRIPTION 
Microprocessor Interface (MPI) Directly Accessed Registers/Buffers 





The Am79C30A/32A can be connected to any general 














purpose 8-bit microprocessor via the MPI. The MCLK Resin moeanc 
from the Am79C30A/32A can be used as the clock for Command Reaister CR’ 
the microprocessor. The MPI is an interrupt driven inter- , t Re - or IR 
face containing all the circuitry necessary for access to a aes a r DR 
the internal programmable registers, Status registers, — area Status Register 1 DSRi 
coefficient RAM, and transmit/receive buffers. D-channel Error Register (2 byte FIFO) DER 
MPI External Interface D-channel Transmit Buffer (8 byte FIFO) +OCTB 
The MPI has the following external connections: a hare a iia aa rica 

Bb Receive Buffer BBRB 
Name Direction Function Bc Transmit Buffer BCTB 

Bc Receive Buffer BCRB 
D7-D0 Bidirectional Data Bus D-channel Status Register 2 DSR2 
A2, Al, & AO Inputs Address Line 
wa = Read enable The &-bit bidirectional data bus (D7-D0) is used to com- 
We npu rite enable municate with these registers. The selection of which 
CS Input Chip Select register(s) is (are) accessed is controlled by the CS, RD, 
heer Input Initialization WR, A2, A1, and AO signals from the microprocessor to 

Output Interrupt the Am79C30A/32A in the following manner (see Figure 


4): 
Register Selection 











CS RD WR A2 Al AO Register(s) Accessed 

0 1 0 0 0 0 Command Register (CR), write only 

0 0 1 0 0 0 Interrupt Register (IR), read only 

0 1 0 0 0 1 Data Register (DR), write only 

0 0 1 0 0 1 Data Register (DR), read only 

0 0 1 (0) 1 0 D-channel Status Register 1 (DSR1), read onty 

0 0 1 0 1 1 D-channel Error Register (DER), read only (2 byte FIFO) 

0 1 0 1 OV 22° D-channel Transmit Buffer (DCTB), write only (8 byte FIFO) 
0 0 1 1 0 0 D-channel Receive Buffer (OCRB), read only (8 byte FIFO) 
0 1 0 1 (0) 1 Bb channel Transmit Buffer (BBTB) write only 

So etn bee een ot Beh cr on es ol pet ess panies a 
0 0 1 1 0 1 Bb channel Receive Buffer (BBRB), read only 

0 1 0 1 1 0 Be channel Transmit Buffer (BCTB), write only 

ce) fe) 1 1 1 [e) Bc channe! Receive Buffer (BCRB), read only 

0 0 1 1 1 1 D-channel Status Register 2 (DSR2), read only 

1 x X x x Xx No access (X = logical ‘0’ or ‘1’) 


Note: The RD and WA signals must never both be low under normal operating conditions. 


ee 
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Command Register (CR), Write only 


The Command Register (CR) is used to hold the index 
for the indirectly accessed registers. The CR is one byte 
wide and divided into two fields, the destination code 
field (DCF) and the operational code field (OCF): 


Bit 7 Bit 0 
els] o||alez|a]2 


DCF OCF 





The ‘Y’ bits in the DCF determine to which block the 
OCF is related. The ‘Y' bits are defined below: 





Am79C30A/32A block Y2 Yi Yo 





RESERVED 0 0 0 
INIT 0 0 1 
MUX 0 1 0 
MAP (Am79C30A only) 0 1 1 
DLC 1 0 0 
LIU 1 0 1 
RESERVED 1 1 0 
RESERVED “41 1 1 


The ‘Z' bits of the OCF contain the operation code used 


to address a specific register within a DCF block. For 
each DCF there is a different set of OCFs. Each of the 
OCFs and their associated data registers are defined in 
the following sections. When the OCF indicates a read 
or write operation is possible, then the appropriate ac- 
cess is achieved by asserting either the read or write sig- 
nals to the Am79C30A/32A. 


Registers within certain groups canbe quickly accessed 
by using internal circuitry which automatically incre- 
ments the indirect address (index value) contained in 
the OCF. The CR is first loaded with the index value, 
then the data bytes are transferred in sequence be- 
tween the Am79C30A/32A and the microprocessor via 
the DR. For example, operation number 5 in the MPI- 
LIU definition allows operations 2 to 4 to be performed 
sequentially without reloading the CR. Whenever the 
CR register is loaded, any previous commands are 
automatically terminated. 


In the following tables the “bytes transferred” numbers 
next to the OCFs are the number of bytes which are read 
or written to the DR after the CR has been loaded. 


MPI-INIT Definition 


The INIT register is used by the microprocessor to select 
the MCLK output frequency and the power-up/idle 


states of the Am79C30A/32A. This register is accessed 
via the ‘Z' bits in the CR as follows: 





OCF 
INITOPERATION Z4 Z3 Z2 Z1 ZO 
(DCF = 001) 


R/W INIT register 


Bytes 
Transferred 


OrsOeod! "OO Viksind 








MPLLIU Definition 
The LIU contains the following registers: 








LIU Registers No. Mnemonic 
LIU Status Register 1 LSR 

LIU Priority 1 LPR 

LIU Mode Registers 2 LMR1, LMR2 
Multtiframe Register 1 MF 
Multiframe S-bit Buffer 1 MFSB 
Multiframe Q-bit Buffer 4 MFQB 





These registers are accessed via the ‘Z’ bits inthe CRas 
follows: 





OCF 
LIUOPERATION 24 23 Z2 Z1 ZO 


Bytes 
(OCF = 101) Transferred 
1. Read LSR 00 0 0 1 1 
2. RAWLPR Oo 0 0 1 @ 1 
3. RAW LMR1 6 0 0 1 1 1 
4. RW LMR2 0010 0 1 
5. Perform 0010 1 3 
Operations 2-4 
6. ReadWriteMF 0 0 1 1 =O 1 
7.ReadMFSB~ 0011 1 1 
8. Write MFQB 0 10 0 0 1 


MPI-MUX Definition 


The MUX contains four microprocessor read/write con- 
trol registers MCR1, MCR2, MCR3, and MCR4. These 
registers are accessed via the ‘Z' bits in the CR as fol- 
lows: 


OCF 
MUX OPERATION 24 Z3 22 Z1Z0 —=—~ Bytes 





(DCF = 010) Transferred 
1. RAW MCRI1 000 01 1 
2. RAW MCR2 0 0 0 t 0 1 
3. RW MCR3 0001 1 1 
4. RAW MCR4 001 0 0 1 
5. Perform 001 0 1 4 


Operations 1-4 


When more than one byte is being transferred due to 
OCF command 5, MCR1 is always accessed first, fol- 
lowed by MCR2, then MCR3, and finally MCR4. 
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Main Audio Processor (MAP) 
(Am79C30A Only) 


This block performs the digital-to-analog (DAC) and 
analog-to-digital (ADC) conversions of the audio sig- 
nals. The codec andfilter functions are implemented us- 
ing digital signal processing techniques to provide sub- 
stantial flexibility and programmability. Analog inter- 
faces are provided for a handset earpiece, a handset 
mouthpiece, a microphone and a loudspeaker. The 
MAP contains the following programmable, user acces- 
sible features: 


Mult-Tone Generator 


This generator can be used to generate a signal consist- 
ing of one or two tones where the frequency and ampli- 
tude of the tone is programmable. The tone(s) can be 
summed into the transmit (and sidetone) path for use as 
a DTMF tone generator, or single tones can be injected 
into the receive path. The tones can be used as ringing 
tones (to the loudspeaker output), dial tones, busy 
signals, ringback tones or other call progress tones. 


Two Attenuation Distortion Correction Filters 


There is one attenuation distortion correction filler in the 
transmit path and one in the receive path. These filters 
can be programmed to modify the frequency character- 
istics of the transmit or receive paths and to equalize for 
the characteristics of the microphones, earpiece 
speaker, or loudspeaker. They can also be used to add 
pre and/or post emphasis to make the signals match 
other characteristics. 


Three Programmable Gain Stages ° 


There is one gain adjustment in the transmit path and 
two in the receive path to provide a wide range of gain 
control. 


Programmable Sidetone Gain 


There is a built-in sidetone path which samples the 
transmit signal, attenuates it by a programmable 
amount, then sums it into the receive path. 
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External Interface 


Audio Input Port Earpiece and Loudspeaker Drivers 
The audio input port consists of two inputs (AINA and Each driver consists of push-pull amplifiers with a low 
AINB) selectable, one at a time, by setting a bit in the impedance output. Either of these audio output ports 


MAP Mode Register 2, (MMR2 bit 0). Signals applied to can be selected, one at a time, via MMR2 bit 1. 
these inputs must be referenced to AREF. 










Ba channel 






AINA To 
AINB—e ‘ MUX 
O - s Transmitter 
4 
‘ © Recelver 
; (A) : 
t t 
) @ 
i ee | 
EAR { =< ‘ 
‘ Ba channel 
saiaia From 


MUX 


IDAC** fe INTERPOLATORS, LPF fe4 R° | 
LS; <n : 
iss 


Tone 
MINIMUM DEFAULT MAXIMUM STEP 
GX OdB + 0dB 12dB  0.5dB 
GER -10dB ** 0dB 18dB  0.5dB 
GR -12dB ** 0dB OdB  0.5db 
STG -18dB ** -18dB 0dB 0.5dB 
“Programmable 
**These registers can also be programmed for inifinite attenuation 09456-31B 


to break the signal path if desired. 


Figure 9. Maln Audio Processor Block Diagram 
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AC Characteristics 
Vec = 5 V +5%, Vss = 0 V; TA = 0°C —>70°C, MCLK = 3.072 MHz 
MAP Analog Characteristics (Am79C30A only) 





Parameter Parameter 
Symbol Description . Test Conditions 





Max Units 













Analog input impedance -1.25 V<Vw <4+1.25 V 
AINA or AINB to AREF fin <4 kHz 








Allowable offset voltage 
at AINA or AINB 


with respect to 
AREF pin 
















+1.25 Vpeak 
(nominal) 


Analog input full scale 


with respect t 
reference level AINA or AINB : 


AREF pin 
















A RLOAD>5400hm «42.5 Vpeak 





Ver Analog output full ; AR fy. 
scale reference level qt OAL 90 pF, or (nominal) 
(PCM code = +3 dBm0) _&3,LS1 toL$2-with RLOAD > 40 ohm 








RLOAD > 40 ohms 
and 
CLOAD < 100 pF 


Zs 





RLOAD > 540 ohms 
and 
CLOAD < 100 pF 


ZEAR 





a 
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s ® — PRELIMINARY 
intel 


82072 _ 

CHMOS HIGH INTEGRATION FLOPPY DISK CONTROLLER 
a Integrated Analog Data Separator with m Programmable Drive Motor On/Off 

Software Selectable Data Rates (250K, Delays 

SOEK SSORK, BI Soe Cet Moe) a Addresses Up to 256 Tracks Directly, 
@ 16 Byte FIFO with Programmable Supports Unlimited Tracks 

Threshold m Implied Seek with Read/Write Disk 
m High Speed Processor Interface Commands 


16 MHz iAPX 386— 1 Wait State 


mpatible with 8272A 
12.5 MHz iAPX 286—1 Wait State m Software Comp 


8 MHz iAPX 286— 0 Wait State @ Controls 8", 51," and 31," Floppy Disk 
Drives 
m Programmable Internal Write : , a 
Precompensation Delays @ Plastic 40 Pin DIP or 44 Pin PLCC 
Packages 


(See Packaging Spec. Order #231369) 


The 82072 CHMOS high integration floppy disk controller solves the many complex disk drive and microproc- 
essor interface issues that exist today, while maintaining software compatibility with the industry standard 
8272A. Features include a sophisticated on-chip analog phase lock loop with software selectable data rates, 
write precompensation delay, and motor on/off delays to simplify the disk drive interface. System interfacing is 
enhanced with the addition of a FIFO which allows a more flexible system to be designed. 


The standard 82072 supports a maximum data rate of 500 Kbits per second. 


The 82072 is fabricated on Intel's advanced CHMOS Ili technology for minimal power consumption and is 
available in a plastic 40 pin DIP or a plastic 44-leaded chip carrier (PLCC) package. 
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Table 1. 82072 Pin Description 


OMA ACKNOWLEDGE: DMA control line that qualifies the RD and 
WR inputs during DMA cycles. 
EAD: 
Ss. 


AD 2 wee READ: Control signal to transfer data to the data bus from the 82072 























WRITE: Control signal to transfer data into the 82072 from the data 
bu 


CHIP SELECT: Control signal that qualifies the RD and WR inputs. 


ADDRESS: 


AO -RD WR Function 
0 0 0 Illegal * 
0 0 1 Read Main Status 
Register 
0 ii 6 Write to the Data Rate Select 
Register ** 


1 No Action 

0 Illegal * 

1 Read from FIFO 

0 Write into FIFO 

1 No Action 

* User must ensure that these inputs do not occur. 
** Change from 8272A—was illegal. 


— st tt = O 
—~—-0OO0O — 





TERMINAL COUNT: Control line from a DMA controller used to 
terminate requests for data transfers. Disk read and write commands 
complete the transfer to the current sector with valid CRC checking/ 
generation. °* 












INDEX: Disk drive signal that indicates the beginning of a track. It is 
used to count retries and delay periods for internal (i.e. Motor On/Off) 
timers and is rising edge triggered. 












Interrupt: Interrupt to host to indicate command completion or that a 
data transfer is required (depending upon the data transfer mode). 
Command completion interrupts are cleared by reading the STO Status 
Register. Data transfer interrupts are cleared when the amount of data 
in the FIFO reaches the full or empty level (depending on FIFO 
direction) or a TC is issued. 


RESET: Places the 82072 in a known idle state. All disk outputs are set 
to a low level. All registers, except those set by the SPECIFY 
command, arecleared. — 

From the trailing edge of Reset, there is a maximum delay of 8 
microseconds until the Main Status register is valid. 

Following reset, the 82072 defaults to polling enabled. 

The default values for the new features are: internal data separator 
enabled, write precompensation value is 125 ns, MOTOR on delay is 
0.0 sec., MOTOR off delay is 5.2 sec., data rate is dependent on DDRE 
setting, FIFO disabled. 
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Table 1. 82072 Pin Description (Continued) 


da 


CRYSTAL 1: External connection for a fundamental mode parallel 
resonant 24 MHz crystal for the internal oscillator. May be driven with 
a MOS level clock instead of a crystal. Refer to the D.C. 
Specifications. 


X2 CRYSTAL 2: If an external clock is supplied on X1, this input must be 
left unconnected (floating). 


ves__{z1.26| 2.24.20] [tociegnowwe, (LOGIBGROUNDSi.0 Aare | Oo | ce Je | te 


DW/DDRE DATA WINDOW/DEFAULT DATA RATE ENABLED: Clock from 
the external PLL logic used to sample the Read Data input. When the 
internal PLL is used, this input pin is used to define the data rate and 
write precompensation values after RESET. DDRE tied high will 
cause the data rate and precompensation bits of the DSR to be 
reinitialized to the default values of 250 Kbps and 125 ns delay when 
a hardware/software reset is issued. DDRE tied low will cause the 
current data rate and precompensation values in the DSR to be 
retained when a hardware reset is issued. When a software reset is 
issued, the DSR will contain those values written into the register. 
DDRE tied low should be used in applications where data rate and 
precompensation information needs to be retained regardless of chip 
reset. 


RDDATA pf ae tA READ DATA: Serial FM.or MFM encoded data from the disk drive. 


READ DATA GATE: This active high output enables an external PLL 
to synchronize to Read Data input from the disk drive. 

LOW DENSITY: This active high output is used by quad density disk 
drives to modify Read/Write head and data channel characteristics. 


This signal is activated when internal PLL is enabled and a data 
transter rate of 250 or 300 Kbps is chosen. 


Analog ground for the Data Separator. It is recommended that care 
be taken to keep AVSS as noise free as possible. A separate 
connection to the ground plane is suggested. 


WRITE ENABLE: Disk drive control signal that sriabiies the head to 
write onto the disk. 


MFM MODE: When an external PLL is used, this output selects 
between single and double density (FM and MFM) modes. 1 = MFM, 
0 = FM mode. 


MOTOR ENABLE: Output used to activate the drive motor on the 
selected drive. Delays are programmable. With one output, this pin 

must be qualified with the cINe select logic to heii motor enables 
for each drive. - 


HEAD SELECT: Signal used to select one oft two sides-on the disk. A 
0 = side 0, a1 = side 1. 


DS1,0 31,32 DRIVE SELECT: These outputs select one of four disk drives. O80. 
: DS1 = 0, O will select drive 0. 
WRDATA 33 37 “| 9 WRITE DATA: FM or MFM encoded serial data to the isk drive. No 
external precompensation is required. ° 
————— rr 
TRKO TRACK 0: Control line from the disk drive that indicat es the head is 
on physical track 0 (outermost track). : 
pase eee 
WP 35 39 WRITE PROTECT: Input from the disk drive that indic : rates if the disk 
is physically write protected. 
- ecient maces 
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Table 1. 82072 Pin Description (Continued) 


READY: Input from the disk drive that indicates whether the drive is 
ready for an operation. 


HEAD LOAD: This output loads the head onto the disk drive if required. 
Typically used by 8" drives. 


STEP: Output used to supply step pulses to the disk drive. 


DIRECTION: This output, in conjunction with STP, causes the drive to 
move the head outward if a “‘0"", and inward if a “1". 





NOTE: 


. 1, Pins 12, 34 of the 44 pin PLCC package are not connected. 


INTRODUCTION 


The 82072 has integrated all of the complex circuitry 
required to interface microprocessor systems with 
disk drives that comply with the IBM System 34 Dou- 
ble Density (MFM) format or the IBM 3740 single 
‘density format (FM). The 82072 is a superset of the 


- 


Figure 2. 82072 Typical System Block Diagram 


8272A. Control over the new features was accom- 
plished by adding extra registers and commands to 
the 82072. The 82072 will function like the 8272A 
Floppy Disk Controller (FDC) after being reset, with 
the added features being set to 8272A compatible 
default values. When accessing the disk drives, the 


' 82072 is programmed the same as the 8272A. 


CONNECTOR 


WRDATA TO DISK 


- RODATA 


CONNECTOR 
TO DISK 
CABLE 


CONTROL 
SIGNALS 
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The microprocessor interface was enhanced by add- 
ing a 16 byte FIFO to reduce the timing constraints 
that most floppy disk controllers impose upon a sys- 


tem. The point at which the 82072 generates a re- — 


quest for a data transfer is selectable within the 16 
byte range of the FIFO. The interface was further 
enhanced to support todays faster microprocessors 
(i.e., 8 MHz 80286, 10 MHz 80186) without incurring 
wait states. A powerdown mode has been added for 
low power or portable applications. With one com- 
mand, the 82072 resets itself and then disconnects 
the power from the internal oscillator. Reset will re- 
connect the clock and once the 82072 is repro- 
grammed (if necessary), it will be ready to read and 
write disks again. 


All of the control logic of the disk interface has been 
integrated into the 82072. Flexibility is maintained by 
allowing the user to select read and write data rates 


rrPzamamaz— 


INTERFACE 
LOGIC 


-unuco 


CRYSTAL 
OSCILLATOR 


DATA RATE 
SELECTION 


=a 


GENERATOR 


*NOTE: 
These pins are not used with the internal PLL 


(without any external hardware); write precompensa- 
tion delays; motor on/off delay; and the track to start 
the precompensation on. The typical design will 
need the 82072, a crystal and high current drivers 
for the signals that interface to the disk drive. The 
new features (when used) need only to be chosen 
once after reset (although they may be modified at 
any time). From then on, the user programs the 
82072 for disk accesses in the same manner as the 
8272A. 


ARCHITECTURE 


Figure 3 is a block diagram of the 82072. The high- 
lighted blocks represent areas that are either com- 
pletely new or highly enhanced. All new features 
were adopted with the requirement of being soft- 
ware compatible with the 8272A. 


REGISTERS 
PRECOMP 


; WE 
SERIAL MFMe 


_ INTERFACE 
LOGIC vco*/LD 


DATA 
SEPARATOR 


ORIVE 
INTERFACE 
CONTROLLER 


290122-4 





Figure 3. 82072 Block Diagram 
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VIB LUNAS 


28F020 
2048K (256K x 8) CMOS FLASH MEMORY 


a Flash Electrical Chip-Erase 
— 2 Second Typical Chip-Erase 


m Quick-Pulse Programming™ Algorithm 
— 10 us Typical Byte-Program 
— 4 Second Chip-Program 
w 10,000 Erase/Program Cycles Minimum 
@ 12.0V +5% Vpp 


@ High-Performance Read 
— 150 ns Maximum Access Time 


m CMOS Low Power.Consumption 
— 10 mA Typical Active Current 
— 50 uA Typical Standby Current 
— 0 Watts Data Retention Power 


@ Noise Immunity Features 


— +10% Vcc Tolerance 
— Maximum Latch-Up Immunity 
through EPI Processing 


ETOX™ II Nonvolatile Flash 

Technology 

—EPROM-Compatible Process Base 

— High-Volume Manufacturing 
Experience 

JEDEC-Standard Pinouts 

— 32-Pin Plastic Dip 

— 32-Lead PLCC 

— 32-Lead TSOP 


Integrated Program/Erase Stop Timer 


° See Packaging Spec., Order #231369 
m Command Register Architecture for Seer Reeeeeree 


Microprocessor/Microcontroller 
Compatible Write Interface 


Intel’s 28FO20 CMOS flash memory offers the most cost-effective and reliable alternative for read/write 
random access nonvolatile memory. The 28F020 adds electrical chip-erasure and reprogramming to familiar 
EPROM technology. Memory contents can be rewritten: in a test socket; in a PROM-programmer socket; on- 
board during subassembly test; in-system during final test; and in-system after-sale. The 28F020 increases 
memory flexibility, while contributing to time- and cost-savings. 


The 28F020 is a 2048-kilobit nonvolatile memory organized as 262,144 bytes of 8 bits. Intel's 28F020 is 
offered in 32-pin plastic DIP, 32-lead PLCC, and 32-lead TSOP packages. Pin assignments conform to JEDEC 
standards for byte-wide EPROMs. 


Extended erase and program cycling capability is designed into Intel's ETOX™ II (EPROM Tunnel Oxide) 
process technology. Advanced oxide processing, an optimized tunneling structure, and lower electric field 
combine to extend reliable cycling beyond that of traditional EEPROMs. With the 12.0V Vpp supply, the 
28F020 performs a minimum of 10,000 erase and program cycles well within the time limits of the Quick-Pulse 
Programming™ and Quick-Erase™ algorithms. 


Intel's 28F020 employs advanced CMOS circuitry for systems requiring high-performance access speeds, low 
power consumption, and immunity to noise. Its 150 nanosecond access time provides no-WAIT-state perform- 
ance for a wide range of microprocessors and microcontrollers. Maximum standby current of 100 pA trans- 
lates into power savings when the device is deselected. Finally, the highest degree of latch-up protection is 
achieved through Intel’s unique EP! processing. Prevention of latch-up is provided for stresses up to 100 mA 
on address and data pins, from —1V to Voc + 1V. 


With Intel's ETOX tI process base, the 28F020 levers years of EPROM experience to yield the highest levels of 
quality, reliability, and cost-effectiveness. 
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Figure 1. 28F020 Block Diagram 


Table 1. Pin Description 










































outputs data during memory read cycles. The data pins are active high 
OE INPUT OUTPUT ENABLE: Gates the devices output through the data buffers 
during a read cycle. OE is active low. 
Note: With Vpp < 6.5V, memory contents cannot be altered. 


Symbol Name and Function 

Cae Ai7 ee ADDRESS INPUTS for memory addresses. Addresses are internally 
latched during a write cycle. - 

hata aac OUTPUT 
and float to tri-state OFF when the chip is deselected or the outputs 
are disabled. Data is internally latched during a write cycle. 

WE INPUT WRITE ENABLE: Controls writes to the control register and the array. 
Write enable is active low. Addresses are latched on the falling edge 

Vpp ERASE/PROGRAM POWER SUPPLY for writing the command 
register, erasing the entire array, or programming bytes in the array. 

/Vcc of sss DEVICE POWER SUPPLY (5V + 10%) 


DATA INPUT/OUTPUT: Inputs data during memory write cycles; 
INPUT CHIP ENABLE: Activates the device’s control oe input buffers, 
decoders and sense amplifiers. CE is active lo high deselects the 
memory device and reduces power consumption to standby levels. 
and data is latched on the rising edge of the WE pulse. 
ii 
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Figure 2. 28F020 Pin Configurations 


Ital 


80C186 
SYSTEM BUS 


Ay~Aig 


DQ,~-00;5 


DQ o-DQ, 


ADDRESS DECODED 
CHIP SELECT 


28F020 


PIS IGUUYUUL ALYY 


DQo- DQ 7 


28F020 


290245-6 





Figure 3. 28F020 in a 80C 186 System 


PRINCIPLES OF OPERATION 


Flash-memory augments EPROM functionality with 
in-circuit electrical erasure and reprogramming. The 
28F020 introduces a command register to manage 
this new functionality. The command register allows 
for: 100% TTL-level control inputs; fixed power sup- 
plies during erasure and programming; and maxi- 
mum EPROM compatibility. 


In the absence of high voltage on the Vpp pin, the 
28F020 is a read-only memory. Manipulation of the 
external memory-control pins yields the standard 
EPROM read, standby, output disable, and se 
Identifier™ operations. 


The same EPROM read, siardtoy: and output disable 
operations are available when high voltage is ap- 
plied to the Vpp pin. In addition, high voltage on Vpp 
enables erasure and programming of the device. All 
functions associated with altering memory con- 
tents—intgligent Identifier, erase, erase verify, pro- 
gram, and program verify—are accessed via the 
command register. 


Commands are written to the register using standard 
microprocessor write timings. Register contents 
serve as input to an internal state-machine which 
controls the erase and programming circuitry. Write 
cycles also internally latch addresses and data 
needed for programming or erase operations. With 
the appropriate command written to the register, 


standard microprocessor read timings output array 
data, access the intgligent Identifier codes, or ot 
data for erase and program verification. 


Integrated Stop Timer 


Successive command write cycles define the dura- 


_ tions of program and erase operations; specifically, 


the program or erase time durations are normally 
terminated by associated program or erase verify 
commands. An integrated stop timer provides simpli- 
fied timing control over these operations; thus elimi- 
nating the need for maximum program/erase timing 
specifications. Programming and erase pulse dura- 
tions are minimums only. When the stop timer termi- 
nates a program or erase operation, the device en- 
ters an inactive state and remains inactive until re- 


. ceiving the appropriate verify or reset command. 


Write Protection 


The command register is only active when Vpp is at 
high voltage. Depending upon the application, the 
system designer may choose to make the Vpp pow- 
er supply switchable—available only when memory 
updates are desired. When Vpp = Vppt, the con- 
tents of the register default to the read comr -d, 
making the 28F020 a read-only memory. | ‘Ss 
mode, the memory contents cannot be altered. 





Table 2. 28F020 Bus Operations 







READ/WRITE Output Disable 





NOTES: 


Vpp(1) CE DQ 9-DQ;, 
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1. Refer to DC Characteristics. When Vpp = Vpp_ memory contents can be read but not written or erased. : 
2. Manufacturer and device codes may also be accessed via a command register write sequence. Refer to Table 3. All other 


addresses low. 


3. Vip is the intgligent Identifier high voltage. Refer to DC Characteristics. 
4. Read operations with Vpp = Vppy may access array data or the intgligent Identifier™ codes. 
5. With Vpp at high voltage, the standby current equals Icc + Ipp (standby). 


6. Refer to Table 3 for valid Data-In during a write operation. 


7. X can be Viz or Vip. 


Or, the system designer may choose to “‘hardwire”’ 
Vpp, making the high voltage supply constantly 
available. In this case, all Command Register func- 
tions are inhibited whenever Vcc is below the write 
lockout voltage Viko. (See Power Up/Down Protec- 
tion.) The 28F020 is designed to accommodate ei- 
ther design practice, and to encourage optimization 
of the processor-memory interface. 


BUS OPERATIONS 


Read 


The 28F020 has two control functions, both of which 
must be logically active, to obtain data at the out- 
puts. Chip-Enable (CE) is the power control and 
should be used for device selection. Output-Enable 
(OE) is the output control and should be used 
to gate data from the output pins, independent of 
device selection. Refer to AC read _ timing 
waveforms. 


When Vpp is high (Vppy), the read operation can be 
used to access array data, to output the intgligent 
Identifier™’ codes, and to access data for program/ 
erase verification. When Vpp is low (Vpp,), the read 
operation can only access the array data. 


Output Disable 


With Output-Enable at a logic-high level (Vj), output 
from the device is disabled. Output pins are placed 
in a high-impedance state. 


Standby 


With Chip-Enable at a logic-high level, the standby 
operation disables most of the 28F020's circuitry 
and substantially reduces device power consump- 
tion. The outputs are placed in a high-impedance 
state, independent of the Output-Enable signal. 
If the 28F020 is deselected during erasure, pro- 
gramming, or program/erase verification, the 
device draws active current until the operation is 
terminated. 


inteligent identifier™ Operation 


The intgligent Identifier operation outputs the manu- 
facturer code (89H) and device code (BDH). Pro- 
gramming equipment automatically matches the de- 
vice with its proper erase and programming algo- 
rithms. 
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With Chip-Enable and Output-Enable at a logic low 
level, raising AQ to high voltage Vip (see DC Charac- 
teristics) activates the operation. Data read from lo- 
cations O000H and 0001H represent the manufac- 
turer's code and the device code, respectively. 


The manufacturer- and device-codes can also be 
read via the command register, for instances where 
the 28F020 is erased and reprogrammed in the tar- 
get system. Following a write of 90H to the com- 
mand register, a read from address location 0000H 
outputs the manufacturer code (89H). A read from 
address 0001H outputs the device code (BDH). 


Write 


Device erasure and programming are accomplished 
via the command register, when high voltage is ap- 
plied to the Vpp pin. The contents of the register 
serve as input to the internal state-machine. The 
state-machine outputs dictate the function of the 
device. 


The command register itself does not occupy an ad- 
dressable memory location. The register is a latch 


used to store the command, along with address and 
data information needed to execute the command. 


The command register is written by bringing Write- 
Enable to a logic-low level (Vi), while Chip-Enable is 
low. Addresses are latched on the falling edge of 
Write-Enable, while data is latched on the rising 
edge of the Write-Enable pulse. Standard microproc- 
essor write timings are used. 


Refer to AC Write Characteristics and the Erase/ 
Programming Waveforms for specific timing 
parameters. 


COMMAND DEFINITIONS 


When low voltage is applied to the Vpp pin, the con- 
tents of the command register default to 00H, en- 
abling read-only operations. 


Placing high voltage on the Vpp pin enables read/ 
write operations. Device operations are selected by 
writing specific data patterns into the command reg- 
ister. Table 3 defines these 28F020 register 
commands. 


Table 3. Command Definitions 


First Bus Cycle Second Bus Cycle 


Pl Address(2) | Data(3)| Operation(1)| Address(2) | Data(3) 





NOTES: 
1. Bus operations are defined in Table 2. 


2. 1A = Identifier address: OOH for manufacturer code, 01H for device code. 
EA = Address of memory location to be read during erase verify. 


PA = Address of memory location to be programmed. 


Addresses are latched on the falling edge of the Write-Enable pulse. 
3. 1D = Data read from location IA during device identification (Mfr = 89H, Device = BDH). 


EVD = Data read from location EA during erase verify. 


PD = Data to be programmed at location PA. Data is latched on the rising edge of Write-Enable. 
PVD = Data read from location PA during program verify. PA is latched on the Program command. 


Figure 6 illustrates the Quick-Erase™ Algorithm. 


Nas 


Following the Read inteligent ID command, two read operations access manufacturer and device codes. 


Figure 5 illustrates the Quick-Pulse Programming™ Algorithm. 
The second bus cycle must be followed by the desired command register write. 
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Buffer Control 


ma_aclk 
ma_aen_ 
sl_aclk 
sl_aen_ 
sbtPiclk 
sbtP1enX_ 
sbtPlenL_ 
sbtP1enM_ 
Pitsbclk 
PitsbenX_ 
PitsbenL_ 
PitsbenM__ 
pl_sel(1:0) 
b_asen_ 


VME 


P1_BR(3:0) _ 
VME_BR_ 
P1_BGIN(3:0) 
VME_BGOUT (3:0) 
VME_BBSY_ 
B_BBSY_ 
P1_AS_ 
VME_AS_ 
P1_DS(1:0)_ 
VME_DS(1:0)_ 
P1_WR_ 
P1_LW_ 
VME_LW_ 
P1_IRQ(7:1)_ 
P1_IACK_ 
VME_IACK_ 
P1_1ACKIN_ 
VME_IACKOUT 
P1_DTACK_ 
VME_DTACK_ 
P1_BERR_ 
VME_BERR_ 
P1_AM53(5:3) 
P1_AM10(1:0) 
VME_AM(5:4) 
P1_SYSR_ 
VME_SYSR_ 
P1_AMEG (23:20) 
P1_A16K(15:14) 
P1_A16B(3:1) 
VME_A(31:29) 
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O - BT1 
O - BT2 

O - BT1 

O - BT4 

O - BT4 

O - BT2 

O - BT2 

O - BT2 

O - BT4 

O - BT2 

O - BT2 

O - BT2 

O - BT8 

O - BT1 

| - SCHMITTN 
O - BT1 

| - SCHMITTN 
O - BT1 

© -BT1 

| — SCHMITTN 
| -SCHMITT 
«BT! 

| - SCHMITTN 
O - BT1 

| - SCHMITTN 
| - SCHMITTN 
O - BT1 

| - SCHMITTN 
| - SCHMITTN 
O- BT1 

| - SCHMITTN 
0» BTi 

| - SCHMITTN 
O - BT1 

| - SCHMITTN 
O - BT1 

| - SCHMITT 

| - SCHMITT 
O - BT1 

| - SCHMITTN 


Master Address Clock 
Master Address Clock 
Master Address Clock 
Master Address Clock 
S-bus to Pi latch 

S-bus to P1 Data enable. 
S-bus to P1 Data enable. 
S-bus to P1 Data enable. 
P1 to S-bus latch. 

P1 to S-bus Data Enable. 
P1 to S-bus Data Enable. 
P1 to S-bus Data Enable. 
Pipeline Buffer Select. 
Address Strobe enable. 


VMEbus Request 

VMEbus Request 

VMEbus Bus Grant 

VMEbus Bus Grant 

VMEbus Bus Busy 

VMEbus Bus Busy 

VMEbus Address Strobe 
VMEbus Address Strobe 
VMEbus Data Strobe 

VMEbus Data Strobe 

VMEbus Write 

VMEbus Long Word 

VMEbus Long Word 

VME interrupts. 

VMEbus Interrupt Acknowledge 
VMEbus Interrupt Acknowledge 
VMEbus Interrupt Acknowledge 
VMEbus Interrupt Acknowledge 
VMEbus Data Acknowledge 
VMEbus Data Acknowledge 
VMEbus Bus Error 

VMEbus Bus Error 

VMEbus Address Modifier 5-3 
VMEbus Address Modifier 1-0 
VMEbus Address Modifier 5-4 
VMEbus System Reset 


O - BT1 VMEbus System Reset 

| - SCHMITT VMEbus Address bit 23-20 
| - SCHMITT VMEbus Address bit 15-14 
| - SCHMITT VMEbus Address bit 3-1 

O - BT1 VMEbus Address bit 31-29 
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Revision 1.0 
VME_SYSCLK O - BT1 VMEBUS Clock 
Test 
od_ | - TLCHT Output disable 
para O- Bi Parametric nand tree output 
Signals 136 
Device Type: LIA5530 
Package Type: PFP144 (10:136 VDD:4 VSS:8) 
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Functional Description 


The S4-VME interfaces the Sbus to the VMEbus. When acting as a Sbus slave, i.e. VMEbus 
Master, VME is a physical device in type 2 or 3 space. During Sbus DMA Master cycles, i.e. 
VME Slave cycles, it will appear as an Sbus slot device. Refer to the Sbus specification for 
further explanation. 


This chip contains the most of the functions required to implement a full VME Interface. In 
addition, buffers to drive VME and to interface Sbus to VME, plus some address decoding 
are needed . The following figure shows how the VME interface will hook up to the rest of the 
CPU. 


Pl 
Sbus 


VME 





P1 Addr, Control 












Sbus Addr | 
Sbus Addr | . ET 
Sbus Control 


buffer 












le = decoder 
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Registers 


The registers can be divided into the following groups: 


1) Registers set on system initialization, replacing board jumpers: 
Interrupt Enable Register: Interrupts handled 
Arbitration mode 


2) Registers used for multi- or co-processing: 
Mail Box Interrupt Register 
Bus Locker Register 
Slave Map Register (also replacing jumper) 


3) Others 
A32 VME Address mapping. Move 512 MByte window 
enable diagnostic loop back. 
Slave Map register bit 0: enable Block Mode transfers 


Following is a list of the VME Interface Registers: 


Type Name Physical Base Size 
1 VME Bus Locker OxEFEO0000 byte 
1 VME IACK cycle OxEFEO0001 byte, A[3:1],A0=1 
1 Mail Box register OxEFE00010 byte 
1 VME Interrupt Enable Register OxEFE00014 byte 
1 A32MAP Register OxEFE00018 byte 
1 Slave Map Register OxEFE0001C byte 
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Stort (4) Bus 
oe, 


Wait for Vpp Ramp to Vppy(1) 


Initialize Pulse-Count 
Data = 40H 
Valid Address/Data 


Duration of Program 
Operation (twHwH1) 


Data = COH; Stops Program 
Operation(3) 


{WHGL 


Read Byte to Verify 
Programming 


Compare Data Output to Data 
Expected 


Data = OOH, Resets the 
Register for Read Operations 


Wait for Vpp Ramp to Vpp; (1) 


3. Refer to principles of operation. 
1. See DC Characteristics for the value of Vpp, and 
VppL. 4. CAUTION: The algorithm MUST BE FOLLOWED 
2. Program Verity is only performed after byte program- to ensure proper and reliable operation of the de- 
ming. A final read/compare may be performed (option- vice. 
al) after the register is written with the Read command. 


Figure 5. 28F020'Quick-PulseProgramming™ Algorithm 
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intel — PRELIMINARY 





Entire Memory Must = 00H 
Before Erasure 


Use Quick-Pulse 


(Figure 4) 
Wait for Vpp Ramp to Vpp}(1) 


TM 


Initialize Addresses and 
Pulse-Count 


Data = 20H 


Data = 20H 


Duration of Erase Operation 
(twHwH2) 

Addr = Byte to Verify; 

Data = AOH; Stops Erase 


Operation(3) 
tWHGL 


Read Byte to Verify Erasure 


Compare Output to FFH 
Increment Pulse-Count 


Data = OOH, Resets the 
Register for Read Operations 


Wait for Vpp Ramp to Vpp,(1) 


1. See DC Characteristics for the value of Vppy and 3. Refer to principles of operation. 


VppL- 

2. Erase Verity is performed only after chip-erasure. A 4. CAUTION: The algorithm MUST BE FOLLOWED 
final read/compare may be performed (optional) after — proper and reliable operation of the de- 
the register is written with the read command. fe 


Figure 6. 28F020 Quick-Erase™ Algorithm 
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Enhanced Serial Communications Controller Devices 
DISTINCTIVE CHARACTERISTICS 4 
m Fastest data rate of any Z8530 = Two independent full-duplex serial channels 
— 8.192 MHz / 2.048 Mb/s ® Asynchronous mode features 
— 10 MHz / 2.5 Mb/s — Programmable stop bits, clock factor, character 
— 12.5 MHz/3 Mb/s length and parity 
— 16.384 MHz / 4.096 Mb/s — Break detection/generation 
— 20MHz/5 Mb/s (prelim) — Error detection for framing, overrun, and parity 
w Low-power CMOS technology @ Synchronous mode features 
@ Pin and function compatible with other NMOS — Supports IBM BISYNC, SDLC, SDLC Loop, 


HDLC, and ADCCP Protocols 
@ Easily interfaced with most CPUs 5 pals gielags Bel prea oer 
: 5 ; — u inclu re ntrol, 
SOrepal De UY HOU RGN PIAS NOs zero insertion and deletion, abort, and 
@ Many enhancements over NMOS Z8530H residue handling 
— Allows 85C30 to be used more effectively in 
high-speed applications 
— Improves interface capabilities 


BLOCK DIAGRAM 


and CMOS Z8530s 
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DISTINCTIVE CHARACTERISTICS (continued) 


@ Enhanced SCC functions support high-speed 

frame reception using DMA 

— 14-bit byte counter 

— 10x19 SDLC/HDLC Frame Status FIFO 

— Independent Control on both channels 

— Enhanced operation does not allow special 
receive conditions to lock the 3-byte DATA 
FIFO when the 10 x 19 FIFO is enabled 


mw Local Loopback and Auto Echo modes 
u@ Internal or external character synchronization 


GENERAL DESCRIPTION 


AMD's Z85C30 is an enhanced pin-compatible version 
of the popular Z8530/Z285C30 Serial Communications 
Controller. The Enhanced Serial Communications Con- 
troller (ESCC) is a high-speed, low-power, multi-protocol 
communications peripheral designed for use with 8- and 
16-bit microprocessors. It has two independent, full-du- 
plex channels and functions as a serial-to-parallel, paral- 
lel-to-serial converter/controller. AMD's proprietary en- 
hancements make the Z85C30 easier to interface and 
more effective in high-speed applications due to a reduc- 
tion in software burden and the elimination of the need 
for some external glue logic. 


The Z85C30 is easy to use due to a variety of sophisti- 
cated internal functions, including on-chip baud rate gen- 
erators, digital phase-locked loops, and crystal oscilla- 
tors, which dramatically reduce the need for external 
logic. The device can generate and check CRC codes in 
any SYNC mode, and can be programmed to check data 
integrity in various modes. The ESCC also has facilities 
for modem controls in both channels. In applications 
where these controls are not needed, the modem con- 
trols can be used for general-purpose I/O. 


This versatile device supports virtually any serial data 
transfer application such as networks, modems, cas- 
settes, and tape drivers. The ESCC is designed for non- 
multiplexed buses and is easily interfaced with most 
CPUs, such as 80188, 80186, 80286, 8080, Z80, 6800, 
68000 and MULTIBUS. 


Enhancements that allow the Z85C30 to be used more 
effectively in high-speed applications include: 


@ a10x 19 bit SDLC/HDLC frame status FIFO array 
® a14-bit SDLC/HDLC frame byte counter 


RELATED AMD PRODUCTS 





Description 








@ 2-Mb/s FM encoding transmit and receive 
Capability using internal DPLL for 16.384-MHz 
product 

@ Internal synchronization between RxC to PCLK 


and TxC to PCLK 

— This allows the user to eliminate extemal 
synchronization hardware required by the NUOS 
device when transmitting or receiving data at the 
maximum rate of 1/4 PCLK frequency. 


@ automatic SDLC/HDLC opening frame flag trans- 
mission 

@ TxD pinforced High in SDLC NRZI mode after closing 
flag 

™ automatic SDLC/HDLC Tx underrun/EOM flag reset 

® automatic SDLC/HDLC Tx CRC generator reset/ 
preset 

w RTS synchronization to closing SDLC/HDLC flag 

uw DTR/REQ deactivation delay significantly reduced 

™ external PCLK to RxC or TxC synchronization re- 


quirement eliminated for PCLK. divide-by-four 
operation 


Other enhancements to improve the Z85C30 interface 
capabilities include: 


@ write data valid setup time to falling edge of WR 
requirement eliminated 
@ reduced INT response time 


@ reduced access recovery time (tac) to 3 PCLK best 
case (3 1/2 PCLK worst case) 

@ improved Wait timing 

@ Write Registers WR3, WR4, WR5, and WR10 made 
readable 

@ lower priority interrupt masking without INTACK 


® complete SDLC/HDLC CRC character reception 





Description 








Am7960 Coded Data Transceiver Am9517A DMA Controller 

80186 Highly Integrated 16-Bit 5380, 53C80 SCSI Bus Controller 
Microprocessor 80188 Highly Integrated 8-Bit 

80286, 80C286 High-Performance 16-Bit Microprocessor 
Microprocessor 

2-286 Z85C30 





CONNECTION DIAGRAMS 
















Top View 
DIPs PLCC, LCC 
1 e 
rE a ee lat ae! 2a (a) 
2 Fogcadd ce 
3 BERBESeanea 
4 Sar: (8512 
5 AB 
6 CE 
7 370 De 
8 36 (1 NC/Optional GND 
9 35 O GND 
34 WREOB 
Z85C30 SYNCB 
RTxCB 
31 [5 RxDB 
TRxCB 
291 TxDB 
181 
aE a a 
os BES SBBBRS 
OW k&beeRlo 
FE 
5E 
10216A-002A S 10216A-003A 
: CD011530 © 3) CD011540 
Note: Pin 1 is marked for orientation. z 
LOGIC SYMBOL 
Data 
Bus Serial 
Data 
Bus Timing Channel 
and Reset Clocks 
Channel 
Controls 
for 
Control Modem, 
DMA, or 
Other 
Serial 
Interrupt Data 
Channel 
Clocks 
Pt 
Channel 
Controls 
‘for 
Modem, 
DMA, or 
Other 
10216A-004A 
LS003300 


+5 V GND PCLK 
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PIN DESCRIPTION 
Bus Timing and Reset 


RD 
Read (Input; Active Low) 


This signal indicates a Read operation and, when the 
SCC is selected, enables the SCC’s bus drivers. During 
the Interrupt Acknowledge cycle, this signal gates the in- 
terrupt vector onto the bus if the SCC is the highest prior- 
ity device requesting an interrupt. 


WR 

Write (Input; Active Low) 

When the SCC is selected, this signal indicates a Write 
operation. The coincidence of RD and WR is interpreted 
as a reset. 


Channel Clocks 


RTxCA, RTxCB 
Recelve/Transmit Clocks (Inputs; Active Low) 


These pins can be programmed in_several different 
modes of operation. In each channel, RTxC may supply 
the receive clock, the transmit clock, the clock for the 
baud rate generator, or the clock of the digital phase- 
locked loop. These pins can also be programmed for use 
with the respective SYNC pins as a crystal oscillator. The 
receive clock may be 1, 16, 32, or 64 times the data rate 
in asynchronous modes. 


TRxCA, TRxCB 
Transmit/Receive Clocks 
(Inputs/Outputs; Active Low) 


These pins can be_programmed in several different 
modes of operation. TRxC may supply the receive clock 
or the transmit clock in the input mode or supply the out- 
put of the digital phase-locked loop, the crystal oscillator, 
the baud rate generator, or the transmit clock in the out- 
put mode. 


Channel Controls for Modem, DMA, 
or Other 


CTSA, CTSB 
Clear to Send (Inputs; Active Low) 


if these pins are programmed as Auto Enables, aLowon 
these inputs enables their respective transmitters. If not 
programmed as Auto Enables, they may be used as 
general-purpose inputs. Both inputs are Schmitt-trigger 
buffered to accommodate slow rise-time inputs. The 
SCC detects pulses on these inputs and may interrupt 
the CPU on both logic level transitions. 


DCDA, DCDB 
Data Carrier Detect (Inputs; Active Low) 


These pins function as receiver enabies if they are pro- 
grammed as Auto Enables; otherwise, they may be used 
as general-purpose input pins. Both are Schmitt-trigger 
buffered to accommodate slow rise-time signals. The 
SCC detects pulses on these pins and may interrupt the 
CPU on both logic level transitions. 


DTR/REQA 
Data Terminal Ready/Request 
(Outputs; Active Low) 


These outputs follow the inverted state programmed 
into the DTR bit in WR5. They can also be used as 
general-purpose outputs or as Request Lines fora DMA 
controller. 


RTSA, RTSB 
Request to Send (Outputs; Active Low) 


When the Request to Send (RTS) bit in Write Register 5 
is set, the ATS signal goes Low. When the RTS bit is re- 
set inthe asynchronous mode and Auto Enable is on, the 
signal goes High after the transmitter is empty. In SYNC 
mode, or in asynchronous mode with Auto Enable off, 
the RTS pins Strictly follow the inverted state of the RTS 
bit. Both pins can be used as general-purpose outputs. 


In SDLC mode, the AUTO RTS RESET enhancement 
described later in this document brings RTS High after 
the last 0 of the closing flag leaves the TxD pin. 


SYNCA, SYNCB 
Synchronization (Inputs/Outputs; Active Low) 


These pins can act either as inputs, outputs, or part of the 
crystal oscillator circuit. In the Asynchronous Receive 
mode (crystal oscillator option not selected), these pins 
are inputs similar to CTS and . In this mode, transi- 
tions on these lines affect the’ state of the Sync/Hunt 
Status bits in Read Register 0 but have no other function. 


In External Synchronization mode with the crystal 
oscillator not selected, these lines also act as inputs. 
In this mode, SYNC must be driven Low two receive 
clock cycles after the last bit inthe SYNC character is re- 
ceived. Character assembly begins on the rising edge 
of the receive clock immediately preceding the activation 
of SYNC. 


In the Intemal Synchronization mode (Monosync and 
Bisync) with the crystal oscillator not selected, these pins 
act as outputs and are active only during the part of the 
receive clock cycle in which SYNC characters are recog- 
nized. The SYNC condition is not latched, so these out- 
puts are active each time a SYNC pattern is recognized 
(regardless of character boundaries). In SOLC mode, 
these pins act as outputs and are valid on receipt of a 
flag. 


W/REQA, W/REQB 

Wailt/Request (Outputs; Open drain when 
programmed for a Wait function, driven High or 
Low when programmed for a Request function) 
These dual-purpose outputs may be programmed as Re- 
quest lines for a DMA controller or as Wait lines to syn- 
chronize the CPU to the SCC data rate. The reset state is 
Wait. 
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Control 

AJB 

Channel A/Channel B Select (Input) 

This signal selects the channel in which the Read or 
Write operation occurs. 

CE 

Chip Enable (Input; Active Low) 

This signal selects the SCC for a Read or Write opera- 
tion. 

b/c 

Data/Control Select (Input) 

This signal defines the type of information transferred to 


or from the SCC. A High means data is transferred; a 
Low indicates a command is transferred. 


Data Bus 


D,-D, 

Data Bus (Input/Output; Three State) 

These lines carry data and commands to and from the 
SCC. 


interrupt 


1El 
Interrupt Enable In (Input; Active High) 


IElis used with IEO to form aninterrupt daisy chainwhen 
there is more than one interrupt-driven device. A High IEI 
indicates that no other higher priority device has an inter- 
- rupt under service or is requesting an interrupt. 


[EO 
Interrupt Enable Out (Output; Active High) 


JEO is High only if IEl is High andthe CPU is not servicing 
an SCC interrupt or the SCC is not requesting an inter- 
rupt (interrupt acknowledge cycle only). IEO is con- 
nected to the next lower priority device's IEI input and 
thus inhibits interrupts from lower priority devices. 


INT 

interrupt Request (Output; Active Low, 

Open Drain) 

This signal is activated when the SCC requests an 
interrupt. 


INTACK 

Interrupt Acknowledge (Input; Active Low) 

This signal indicates an active interrupt acknowledge cy- 
cle. During this cycle, the SCC interrupt daisy chain set- 
tles. When RD becomes active, the SCC places an inter- 
rupt vector on the data bus (if IE! is High). INTACK is 
latched by the rising edge of PCLK. 


Serial Data 


RxDa, RxDB 

Receive Data (Inputs; Active High) 

These input signals receive serial data at standard TTL 
levels. 


TxDA, TxDB 

Transmit Data (Outputs; Active High) 

These output signals transmit serial data at standard 
TTL levels. 


Miscellaneous 


GND 

Ground 

PCLK 

Clock (Input) 

This is the master SCC clock used to synchronize inter- 
nal signals. PCLK is not required to have any phase rela- 
tionship with the master system clock. PCLK is a TTL- 
level signal. Maximum transmit rate is 1/4 PCLK. 


Vee 
+5 V Power Supply 


RR SR 
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ARCHITECTURE 


The ESCC internal structure includes two full-duplex 
channels, two 10 x 19 bit SDLC/HDLC frame status 
FIFOs, two baud rate generators, internal control and in- 
terrupt logic, and a bus interface to a non-mulliplexed 
bus. Associated with each channel are a number of Read 
and Write registers for mode control and status informa- 
tion, as well as logic necessary to interface with modems 
or other external devices (see Logic Symbol). 


The logic for both channels provides formats, synchroni- 
zation, and validation for data transferred to and fromthe 
channel interface. The modem control inputs are moni- 
tored by the control logic under program control. Allof the 
modem control signals are general-purpose in nature 
and can optionally be used for functions other than mo- 
dem control. 


The register set for each channel includes ten control 
(Write) registers, two SYNC character (Write) registers, 
and four status (Read) registers. In addition, each baud 
rate generator has two (Read/Write) registers for holding 
the time constant that determines the baud rate. Finally, 
associated with the interrupt logic is a Write register for 
the interrupt vector accessible through either channel, a 
Write-only Master Interrupt Control register, and three 


Read registers: one containing the vector with status in- 
formation (Channel B only), one containing the vector 
without status (A only), and one containing the interrupt 
pending bits (A only). 


The registers for each channel are designated as fol- 
lows: 


WRO-WR15—Write Registers 0 through 15. An addi- 
tional Write register, WR7 Prime (WR7’7, is available for 
enabling or disabling additional SDLC/HDLC enhance- 
ments if bit Do of WR15 is set. 


RRO-RR3, RR10, RR12,RR13, RR15—Read Registers 
0 through 3, 10, 12, 13, and 15. 


If bit D2 of WR15 is set, then two additional Read regis- 
ters, RR6 and RR7, are available. These registers are 
used with the 10 x 19 bit Frame Status FIFO. 


Table 1 lists the functions assigned to each Read 
and Write register. The ESCC contains only one 
WR2 and WR39, but they can be accessed by either 
channel. All other registers are paired (one for 
each channel). - 









Internal 
Control 





Interrupt 


ce 
t tf 


+5 V GND PCLK 











Channel B 










BCDB 
10216A-001A 
BD008260 
Figure 1. Block Diagram of ESCC Architecture 
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~ Data Path 


The transmit and receive data path illustrated in Figure 2 
is identical for both channels. The receiver has three 
8-bit buffer registers in a FIFO arrangement, in addition 
to the 8-bit receive shift register. This scheme creates 
additional time for the CPU to service an interrupt at the 
beginning of a block of high-speed data. Incoming data 


The transmitter has an 8-bit transmit data buffer register 


are routed through one of several paths (data or CRC) 
depending on the selected mode (the character length in 


asynchronous modes also determines the data path). 


loaded {rom the internal data bus and a 20-bit transmit 
shift register that can be loaded either from the sync- 
character registers or from the transmit data register. De- 
pending on the operational mode, outgoing data are 
routed through one of four main paths before they are 
transmitted from the Transmit Data output (TxD). 


Table 1. Read and Write Register Functions 





Read Register Functions 


Write Register Functlons 








RRO =‘ Transmit/Receive buffer status and External status WRO Command Register, Register Pointers CRC 
‘RR1 Special Receive Condition status’ initialize, initialization commands for the various 
(also 10 x 19 bit FIFO Frame Reception Status if modes, shift right/shift left command 
WR15 bit D, is set) WR1_Interrupt conditions and data transfer mode 
RR2 Modified interrupt vector definition 
(Channel B only) WR2___ Interrupt vector (accessed through either channel) 
Unmoditied interrupt vector WR3 Receive parameters and control 
(Channel A only) WR4 __ Transmit/Receive miscellaneous parameters and 
RR3 Interrupt Pending bits modes 
(Channel A only) WR5 __ Transmit parameters and controls 
RR6 ~—_—LSB Byte Count (14-bit counter) WR6 ~~ Syne ccharacter or SOLC address field 
(if WR15 bit D, set) WR7 Sync character or SDLC flag 
RR7 ~=MSB Byte Count (14-bit counter) WR7’ SDLC/HDLC enhancements (if bitD, of WR15 is set) 
and 10 x 19 bit FIFO Status (if WR15 bit D, is set) WR8 __ Transmit buffer 
RR8 Receive buffer WR9 Master interrupt control and reset (accessed 
RR10_ = Miscellaneous XMTR, RCVR status through either channel) 
*RR12 Lower byte of baud rate generator time constant WR10_ Miscellaneous transmitter/receiver control bits, data 
RR1i3 Upper byte of baud rate generator time constant encoding 
RR15_— External/Status interrupt information WR11. Clock mode control, Rx and Tx clock source 
; WR12_ Lower byte of baud rate generator time constant 
WR13 Upper byte of baud rate generator time constant 
WR14_ Miscellaneous control bits, DPLL control 
WR15_— External/Status interrupt control 
a 
2-294 Z85C30 
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Signetics 


Linear Products 


DESCRIPTION 


The NE5170 is an octal line driver which 
is designed for digital communications 
with data rates up to 100kb/s. This 





NES1/0 | 


Preliminary Specification 


FEATURES 


@ Meets EIA RS-232C/423A and 
CCITT V.10/X.26 


e Simple slew rate programming 


Octal Line Driver 


PIN CONFIGURATIONS 
N Package 


device meets all the requirements of EIA 
standards RS-232C/RS-423A and 
CCITT recommendations V.10/X.26. 
Three programmable features: (1) output 
slew rate, (2) output voltage level, and 
(3) 3-State control (high-impedance) are 
provided so that output characteristics 
may be modified to meet the require- 
ments of specific applications. 


with a single external resistor 

e 0.1 to 10V/pus slew rate range 

e High/Low programmable voltage 
output modes 

e TTL compatible inputs 


APPLICATIONS 

© High-speed modems 

e High-speed parallel 
communications 

e Computer I/O ports 

e Logic level translation 


Zl 
Pe fle oo 8 Sard B 


2 
oO 


FUNCTION TABLE 


OUTPUT VOLTAGE (V) 


LOGIC : 
ENABLE RS-232C : 
INPUT RS-423A! 
Low Output Mode’ | High Output Mode? 


RY A I 
Cow [ee we | ee 


NOTES: 
1. Vog = +10V and Veg =-10V; Ay = 3kQ 
2. Vog = + 12V and Veg =-12V; Ry = 3kQ 


ORDERING CODE 














December 1987 


Signetics Linear Products Preliminary Specification 


Octal Line Driver NE5470 





ABSOLUTE MAXIMUM RATINGS 





DC ELECTRICAL CHARACTERISTICS Voc = 10V 10%: Veg =-10V +10%; +MODES = OV; Agu = 2k, O°C < Ta <70°C, 
; ‘ unless otherwise specified. 








TEST CONDITIONS 










Ry = 45024 


Ry = 3k95, C, = 2500pF 
Vin = 2.0V 
Ry = 3kN4 


Ry = 3kQ5, Cy = 2500pF 


. Output. unbalance voltage Voc = [Vee]. Ri = 45024 
Output leakage current [Vol = 6V, ENABLE = 2V or Voc = Veg = OV 






















Loti | Logic ‘1’ input current 

[Tres [reupat shor ereuitcurent™ | 

Input clamp voltage 

| tcc | ee : : No Load 
Sup) 

[ee a : No Load 


ply current 





NOTES: : : 
1 Maximum current per driver. Do not exceed maximum power dissipation if more than one output is on. 
2. High-impedance mode. ©... ; 

3. Minimum value of the resistor used to set the slew rate. 

4. Vou. Vor at Ry = 4502 will be 2 290% of Vox. Vor at RL = ©. 

5. High Output Mode; + MODE pin = Voc; -MODE pin = Vee; 9V < Voc < 13; ~9V 2 Vee &-13V. 
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Octal Line Driver NE5170 





AC ELECTRICAL CHARACTERISTICS Voc = +10V; Vee =-10V; Mode = GND, 0°C <T, <70°C 


SYMBOL 













PARAMETER TEST CONDITIONS 


R, = 450, Cy = 50pF 
or 
Ry = 3k, Cy = 2500pF 


R, = 450, Cy = 50pF 
or : 
Ry = 3k, Cy = 2500pF 


Rg = 200k 

Ry = 450, C, = SOpF 
or 

Ry, = 3k, C, = 2500pF 

Rs, = 200k 

R, = 450, C_ = SOpF 
or 

Ry = 3k, Cy = 2500pF 


Propagation delay output high to high-impedance 























Propagation delay output low to high-impedance 












Propagation delay high-impedance to high output 














Propagation delay high-impedance to low output 


Output slew rate! 


NOTE: 
Sf: Load condition. (A) For Rg_ < 4k use Ry = 4502; C, = SOpF; (B) for Rs, > 4kQ use either RL = 4502, C_ = SOpF or RL = 3kQ, Cy = 2500pF. 


AC PARAMETER TEST CIRCUIT AND WAVEFORMS 


+10V 


ENABLE 


Ow 
- MODE GND +MODE Vee 


NOTES: 
14. See AC eloctrical characteristics table for values of Ag. Ry and Cy. 
2. Vy pulse: Frequency = 1kHz, duty cycle = 50%, Zout = 502, | = | S 10ns. 
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Signetics 


Linear Products 


DESCRIPTION 
The NE5180 and NE5181 are octal line 
‘receivers designed to interface data ter- 
-minal equipment with data communica- 
tions equipment. These devices meet 
_ the requirements of EIA standards RS- 
232C, RS-423A, RS-422A, and CCITT 
V.10, V.11, V.28, X.26 and X.27. The 
NE5180 is intended for use where the 
data transmission rate is up to 200 kb/s. 
The NE5181 covers the entire range of 
data rates up to 10 Mb/s. The difference 
in data rates for the two devices results 
from the input filtering of the NE5180. 
These devices also provide a failsafe 
‘feature which protects against certain 
* input fault conditions. 


FUNCTION TABLE 


Both inputs open or grounded 


NOTE: 


1. Vip is defined as the non-inverting terminal input voltage minus the inverting terminal input vottage. 


ORDERING INFORMATION 


DESCRIPTION 









28-Pin PLCC 
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FAILSAFE 
ie INPUT 
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NE5180/NE5181 


Octal Differential Line 
Receivers 


Preliminary Specification 


FEATURES 

e Meets EIA RS-232C/423A/422A 
and CCITT V.10, V.11, V.28 

e Single +5V supply — TTL 
compatible outputs 

e Differential inputs withstand 
+25V 


e Failsafe feature 

e Input noise filter (NE5180 only) 
e Internal hysteresis 

e Available in SMD PLCC 


PIN CONFIGURATIONS 









N Package 


APPLICATIONS 

e High-speed modems 

e High-speed parallel 
communications 


e Computer {/O ports 
e Logic level translation 


TOP VIEW 
A Package 


B- Ao A+ A- Veo Ho H+ 


OV 










ToP VIEW 


853-1272 90095 


4-26 
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Octal Differential Line Receivers NE5180/NE5184 





ABSOLUTE MAXIMUM RATINGS Ta = +25°C 


[-svmeou | panaweren_—«—iRaTWG | uN 
| Po [Power dissipation «toot 
[ves | Spy votae dP 
[vow [Gommonmoderange «dt 
Differential input voltage (oho. eral Maps. alll 

















Vu, Vin, © Vu, Vin, 








a 
N 


=a 


c 
5/ 2 
+ 





Inputs open or 
shorted to 


0 < lout < 8mA, Viaitsate = OV 


0 > lout -400pA, Visiisate = Voc : 


< 













Differential input high4 
threshold 


Ls) 
N 

















|Rs=500' | Lees 
tate input low haa . a" at V 
ee a CK 
pin neste ed folags [fo nn 
ele 





27 


High level output voltage 


N 
N 
v 












NOTES 3 
1. Rg is a resistor in series with each input. 

2. Measured after 100ms warm-up (at 0°C), 

3. Only 1 output may be shorted at a time and then only for a maximum of 1 second. 
4. See Figure 1 for threshold and hysteresis definitions. 


AC ELECTRICAL: CHARACTERISTICS Vec = +5V +5%, 0°C <T, <+70°C 

















PARAMETER TEST CONDITIONS 









C, = 50pF, Vip = +1V 
| tea | Propagation delay — high to low C, = 50pF, Vip = +1V 


ae Acceptable input frequency Unused input grounded, Vip = + 200mv! _ 
a Rejectable input frequency Unused input grounded, Vip = +t 500mv 5.5 | 


1. Vip = # 1V for NE5S181. 
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8K X 8 ZEROPOWER 
TIMEKEEPER RAM 





ADVANCED DATA 


« INTEGRATED ULTRA LOW POWER SRAM, 
REAL TIME CLOCK, CRISTAL, POWER-FAIL 
CONTROL CIRCUIT AND BATTERY 


a BYTEWIDE™ RAM-LIKE CLOCK ACCESS 


= BCD CODED YEAR, MONTH, DAY DATE, 
HOURS, MINUTES AND SECONDS 


a SOFTWARE CONTROLLED CLOCK 
CALIBRATION FOR HIGH ACCURACY APPLI- 
CATIONS 


{ 
= PREDICTED WORST CASE BATTERY (Plastic with Battery Top Hat) 
STORAGE LIFE OF 11 YEARS @ 70°C 


a PIN AND FUNCTION COMPATIBLE WITH 
JEDEC STANDARD 8K X8 SRAMs PIN CONNECTIONS 


a AUTOMATIC POWER-FAIL CHIP 
DESELECT/WRITE PROTECTION 


MK48T08-10 


MK48T08-12 
MK48T08-15 


MK48T08-20 









ADDRESS INPUTS 
CHIP ENABLE 
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This is advance information on a new product now in development or undergoing evaluation. Details are subject to change without notice 337 
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TRUTH TABLE MK48T08 
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DESCRIPTION 


The MK48T08 combines an 8K x 8 full CMOS 
SRAM, a BYTEWIDE accessible real time clock, 
a crystal and a long life lithium carbon mono- 
fluoride battery, all in a single plastic DIP packa- 
ge. The MK48TO8 is a non-volatile pin and function 
equivalent to any JEDEC standard 8K x 8 SRAM. 


FIGURE 1. BLOCK DIAGRAM 















VOLTAGE SENSE 
AND 


SWITCHING 
CIRCUITRY 
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It also easily fits into many EPROM and EEPROM 
sockets, providing the non-volatility of the PROMs 
without any requiremnt for special write timing, or 
limitations on the number of writes that can be per- 
formed. 

Access to the clock is as simple as conventional 
BYTEWIDE RAM access because the RAM and the 
clock are combined on the same die. As figure 1 
indicates, the TIMEKEEPER registers are located 
in the upper eight locations of the RAM. The regi- 
Sters contain, beginning at the top; year, month, 
date, day, hour, minutes, and seconds data in 24 
hour BCD format. Corrections for 28, 29 (Leap 
Year), 30 and 31 day months are made automati- 
Cally. The eighth location is a Control register. The- 
Se registers are not the actual clock counters; they 
are BiPORT read/write Static RAM memory loca- 
tions. The MK48TO08 includes a clock control cir- 
cuit that, once every second, dumps the counters 
into the BiIPORT RAM. 

Because the Clock Registers are constructed using 
BiPORT memory cells, access to the rest of the 
RAM proceeds unhindered by updates to the TI- 
MEKEEPER registers, even if the TIMEKEEPER 
registers are being updated at the very moment 
another location in the memory array is accessed. 
The MK48T08 also has its own Fower-fall Detect 
circuit. The circuit deselects the device when ever 
Vcc is out of range, providing a high degree of da- 
ta security in the midst of unpredictable system 
Operations brought on by low Vcc. 


— 





KK 


READ MODE 


The MK48T08 is the Read Mode whenever W (Wri- 
te Enable) is high and E (Chip Enable) is low. The 
device architecture allows ripple-through access to 
any of the 8192 address locations in the static sto- 
rage array. Valid data will be available at the Data 
I/O pins within ta, after the last address input si- 
gnal is stable, providing that the E and G access 
times are satisfied. 

It E or G access times are not yet met, valid data 


FIGURE 2. READ CYCLE TIMING 





‘eee 
ca pece. 
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will be available at the latter of Chip Enable Access 
Time (tcea) or at Output Enable Access Time 
(toga). The state of the eight three-state Data I/O 
signals is controlled by E and G. If the Outputs are 
activated before taa, the data lines will be driven 
to an indeterminate state _until taa. If the Address 
inputs are changed while E and G remain low, out- 
put data will remain valid for Output Data Hold Ti- 
me (tox) but will go indeterminate until the next 
Address Access. 


wre, 


WH 


tonaz 


AC ELECTRICAL CHARACTERISTICS (READ CYCLE) 


(0°C < TA < +70°C, Voc=5.0 V + 10%/-5%) 






PARAMETER 


wn 

2 > 
zu 
no wn 
< 
23 


(o) 


tac |tavav| Read Cycle Time 
vav| Address Access Time 


ELaV| Chip Enable Access Time 


6 
> 


- 
> 
Aa 


Chip Enable Data Off Time 


Lav| Output Enable Access Time 


) 


roy 
a |e |e 


Haz} Output Enable Data Off Time 


toeL 


9) 


5 )o |e 
0 15 


teLax| Chip Enable to Q Low-Z 
tpHax| Output Hold from Address 


a 
al 








xltoemmoowz || (| et | et tel tel 
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WRITE MODE read or write cycle. Data-in must be valid tps prior 
—__ to the end of write and remain valid for {pH af- 
The MK48T08 is in the Write Mode whenever W __ terward. a: 
and E control lines are low. The start of a write is Because G is a Don't Care in the Write Mode and 
referenced to the latter occurring falling edge of alowonWvwill return the outputs to High-Z, G can 
W or E. A write is terminated by the earlier rising _ be tied low and two-wire RAM control can be im- 
edge of Wor E. The addresses must be held valid plemented. A low on W will disable the Outputs 
throughout the cycle. E or W must return high for twez after W falls. Take care to avoid bus conten- 
minimum of twr prior to the initiation of another tion when operating with two-wire control. 


FIGURE 3. WRITE CYCLE TIMING 


VALIO 
OUT 





AC ELECTRICAL CHARACTERISTICS (WRITE CYCLE) 
(0°C < TA <= +70°C, Voc=5.0 V+ 10%/-5%) 


ALT. | STD. 
es [wn [ [| we [woe [ [i 
[ne [avin retin [ooo] [om] fm] [ao] 


wi 
| tas ftav Address Setup Time W Low 


[ns [wer atiow sauptne uw | of [of Tf [of 


ear|erpernewewawie| «| lio] [wo] [we] Le [a 
wn vas ensowne | 00 | 
a [faa vac eae | 0 | | 


413 r 
a 497, Sttmonttomones 















PARAMETER 
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UNITS| NOTE 


AC ELECTRICAL CHARACTERISTICS (WRITE CYCLE) (Continued) 
(0°C < TA < +70°C, Voc =5.0 V+ 10%/-5%) 


ALT. | STD. MK48T08-10 | MK48T08-12 MK48T08-15 | MK48T08-20 
PARAMETER 
ou, | co co 


co 
Fo fl wae oe | 
For fal Ei aaoenc_[ 
| twa were W High to W Low next Cycle | 10 | 
| tos ftovwe Data Setup Time to W High | 50 | 
tos ftoven| Data Setup Time to E High | 50 | 
For ce oa oe a6 
ton | me 















teHpx| Data Hold Time E High 


AC TEST CONDITIONS 
Input Levels: 0.6V to 2.4V 


Transition Times: 5 ns 
input and Output Timing 
Reference Levels: 0.8V or 2.2V 





CAPACITANCE 


SYMBOL | PARAMETER 


C, Capacitance on all pins (except DQ) 
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FIGURE 5S. POWER-UP / POWER-DOWN CONDITIONS 


Vero (Max) 
V PED (Min) 


DATA RETENTION TIME 
tor 





AC ELECTRICAL CHARACTERISTICS (POWER-UP/DOWN TIMING) 
(0°C < TA < +70°C) 


: tro | E or W at Vin, before Power Down 

8 CS 

[le inet otters [ef 
Ps eetegee Te 

Ss SS 

[ie [fe avyaw rere |e 


DC ELECTRICAL CHARACTERISTICS (POWER-UP/DOWN TRIP POINTS) 
(0°C < TA <+70°C) 


SYMBOL | PARAMETER 
Power-fail Deselect Voltage 


Battery Back-up Switchover Voltage 
; | ton | Expected Data Retention Time (Oscillator On) 


CAUTION 
















UNITS 
us 










Negative undershoots below —0.3 volts are not allowed 
on any pin while in the Battery Back-up mode. 
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CLOCK OPERATIONS 
Reading the Clock 


Updates to the TIMEKEEPER registers should be 
halted before clock data is read to prevent reading 
of data in transition. Because the BiPORT TIME- 
KEEPER cells in the RAM array are only data re- 
gisters, and not the actual counter, updating the 
registers can be halted without disturbing the clock 
itself. 


Updating is halted when a ‘‘1”' is written into the 
“Read” bit, the seventh most significant bit in the 
Control Register. As long as a “‘1"’ reamins in that 
position, updating is halted. After a Halt is issued, 
the registers reflect the count, that is day, date, and 
time that were current at the moment the Halt com- 
mand was issued. 


All of the TIMEKEEPER register are updated simul- 
taneously. A Halt will not interrupt an update in pro- 
gress. Updating is within a second after the bit is 
reset a 0". 


FIGURE 6. THE MK48T08 REGISTER MAP 


ADDRESS 


1FFF 












ST=STOP BIT 
W= WRITE BIT 


' Da ee ae ee 
L57. SSounemsces 










R=READ BIT 
S$ =SIGNBIT 


Setting the Clock 


The eight bit of the Control register is the “Write” 
bit. Setting the Write bit to a ‘*1"’, like the Read bit, 
halts updates to the TIMEKEEPER registers. The 
user can then load them with the correct day, da- 
te and time data in 24 Hour BCD format. Reset- 
ting the Write bit to a “O" then transfers those 
values to the actual TIMEKEEPER counters and 
allows normal operation to resume. 


Stopping and Starting the Oscillator 


The oscillator may be stopped at any time. If the 
device is going to spend a significant amount of 
time on the shelf, the oscillator can be turned off 
to minimize current drain from the battery. The 
“Stop” bit is the MSB for the Seconds Register. 
Setting it to a ‘‘1"’ stops the oscillator. 





. FUNCTION 


YEAR 00-99 
MONTH 
DATE 
DAY" 
HOUR 
MINUTES 
SECONDS 
CONTROL 





FT =FREQUENCY TEST 
X=UNUSED 
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Calibrating the Clock 


The MK48T08 is driven by a quartz controlled oscil- 
lator with a nominal frequency of 32768 Hz. The 
crystal is mounted in the tophat along with the bat- 
tery. A typical MK48T08 is accurate within +1 mi- 
nute per month at 25°C without calibration. The 
devices are tested not to exceed 35 PPM (parts per 
million) oscillator frequency error at 25°C, which 
comes to about + 1.53 minutes per month. Of cour- 
se the oscillation rate of any crystal changes with 
temperature. Figure 6. shows the frequency error 
that can be expected at various temperatures. 


Most clock chips compensate for crystal frequen- 
cy and temperature shift error with cumbersome 
trim capacitors. The MK48T08 design, however, 
employs periodic counter correction. The calibra- 
tion circuit adds or subtracts counts from the oscil- 
lator divider circuit at the divide by 128 stage, as 
shown in figure 7. The number of times pulses are 
blanked (subtracted, negative calibration) or split 
(added, positive calibration) depends upon the va- 
lue loaded into the five bit Calibration byte found 
- in the Control Register. Adding counts speeds the 
clock up, subtracting counts slows the clock down. 


FIGURE 7. ADJUSTING THE DIVIDE BY 128 


NORMAL | | | | | | | | 
POSITIVE 

CLAIBRATION 

NEGATIVE ..« 

CALIBRATION 


The Calibration byte occupies the five lower order 
bits in the Control register. This byte can be set 
to represent any value between 0 and 31 in binary 
form. The sixth bit is a sign bit; ‘'1"’ indicates posi- 
tive calibration, ‘‘0’’ indicates negative calibration. 
Calibration occurs within a 64 minute cycle. The 
first 62 minutes in the cycle may, once per minu- 
te, have one second either shortened or lengthe- 
ned by 256 oscillator cycles, that is one tick of the 
divide by 128 stage of the clock chain. If a binary 
“1” is loaded into the register, only the first 4 
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minutes in the 64 minute cycle will be modified: if 
a binary 6 is loaded, the first 24 will be affected and 
so on. 


Therefore, each calibration step has the effect of 
adding or subtracting 512 oscillator cycles for every 
125,829, 120 actual oscillator cycles, that is 4.068 
PPM of adjustment per calibration step gin the user 
126.14 PPM calibration range. Assuming that the 
oscillator is in fact running at exactly 32768 Hz, 
each of the 31 increments in the Calibration byte 
would represent 10.7 seconds per month. 


Two methods are available for ascertaining how 
much calibration a given MK48T08 may require. 
The first involves simply setting the clock, letting 
it run for a month and comparing it to a known ac- 
curate reference (like WWV broadcasts). While that 
may seem crude, it allows the designer to give the 
end user the ability to calibrate his clock as his en- 
vironment may require, even after the final product 
is packaged in a non-user serviceable enclosure. 
All the designer has to do is provide a simple utili- 
ty that accessed the Calibration byte. The utility 
could even be menu driven and made foolproof. 


The second approach is better suited to a manu- 
facturing environment, and involves the use of so- 
me test equipment. When the Frequency Test (FT.) 
bit, the seventh-most significant bit in the day Re- 
gister, is set to a ‘‘1"", and the oscillator.is running 
at 32768 Hz, the LSB (DQ0) of the Seconds Regi- 
ster will toggle at a 512 Hz. Any deviation from 512 
Hz indicates the degree and direction of oscillator 
frequency shift at the test temperature. For exam- 
ple, a reading of 512.01024 Hz would indicate a 
+ 20 PPM oscillator frequency error, requiring a 
-5 (000101) to be loaded into the Calibration Byte 
for correction. Note that setting or changing the Ca- 
libration Byte does not affect the Frequency Test 
output frequency. The device must be selected and 
addresses must stable at Address 1FF9 when rea- 
ding the 512 Hz on DQO. 


The FT. bit must be set using the same method 
used to set the clock, using the Write bit. The LSB 
of the Seconds Register is monitored by holding 
the MK48TO08 in an extended read of the Seconds 
Register, without having the Read bit set. The FT. 
bit MUST be reset to a ‘‘0”’ for normal clock ope- 
rations to resume. 








FREQUENCY ERROR (PPM) - 


20 30 
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FIGURE 8. FREQUENCY ERROR WITHOUT CALIBRATION 


40 50 


TEMPERATURE (DEGREES CELCIUS) 


DATA RETENTION MODE 


With Vcc applied, the MK48T08 operates as a 
conventional BYTEWIDE static RAM. Should the 
supply voltage decay, the RAM will automatically 
power-fail deselect, write protecting itself when 
Voc falls within the VpFp(max), Vprp(min) win- 
dow. The MK48T08 has a Vprp(max)-VpFp(min) 
window of 4.75 volts to 4.5 volts, allowing users 
constrained to a 10% power supply specification 
to use the device. 


Note: A mid-write cycle power failure may corrupt 
data at the currently addressed location, but does 
not jeopardize the rest of the RAM’s content. At 
voltages below Vprp(min), the user can be assu- 
red the memory will be in a write protected state, 
provided the Vcc fall time does not exceed tr. The 
MK48TC8 may respond to transient noise spikes 
that reach into the deselect window if this should 
occur during the time the device is sampling Vcc. 
Therefore decoupling of the power supply lines is 
recommended. 


The power switching circuit connects external Voc 
to the RAM and disconnects the battery when Vcc 
rises above Vso. Normal RAM operation can re- 
sume trec after Voc exceeds VpFp(max). Caution 
should be taken to keep E or W high as Vcc rises 
past Vprp(min) as some systems may perfom 








inadvertent write cycles after Vcc rises but befo- 
re normal system operation begins. 


PREDICTING BACK-UP SYSTEM LIFE 


The useful life of the battery in the MK48T08 is ex- 
pected to ultimately come to an end for one of two 
reasons; either because it has been discharged wile 
providing current to an external load; or because 
the effects of aging render the cell useless before 
it can actually be discharged. Fortunately, these 
two effects are virtually unrelated, allowing di- 
scharge, or Capacity Consumption and the effects 
of aging, or Storage Life to be treated as two 
independent but simultaneous mechanisms, the 
earlier of which defines Back-up System life. 


The current drain that is responsible for Capacity 
Consumption can be reduced either by applying 
Vcc or turning off the oscillator. With the oscilla- 
tor off, only the leakage currents required to main- 
tain data in the RAM are flowing. With Vcc on, the 
battery is disconnected from the RAM. Because the 
leakage currents of the MK48T08 are so low, then 
can be neglected in practical Storage Life calcu- 
lations. 

Therefore, to extent the life of components that are 
just sitting on the shelf (not in system use) the oscil- 
lator should be turned off. 
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FIGURE 9. MK48T08 PREDICTED BATTERY STORAGE LIFE VS. TEMP. 
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' Predicting Storage Life 


' Figure 9 illustrates how temperature affects Sto- 
rage Life of the MK48T08 battery. As long as Voc 
is applied or the oscillator is turned off, the life of 


the battery is controlled by temperature and is vir- . 


tually unaffected by leakage currents drawn by the 
MK48T08. 


Storage Life predictions presented in Figure 9 are 
extrapolated from temperature accelerated life-test 
data collected in over 100 million device hours of 
continuing bare cell and encapsulated cell batte: y 
testing by SGS-THOMSON. Obviously, tempera- 
ture accelerated testing cannot identify non- 
temperature dependent failur mechanisms. Howe- 
ver, in view of the fact that no random cell failures 
have been recorded in any of SGS-THOMSON’s 
on going battery testing since it began in 1982, we 
believe the chance of such failure mechanisms sur- 
facing is extremely small. 

For the purpose of the testing, a cell failure is defi- 
ned as the inability af a cell stabilized a 25°C to 
produce a 2.0 volt closed-circuit voltage across a 
250K load resistance. 
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A Special Note: The summary presented in Figu- 
ra 9 represents a conservative analysis of the da- 
ta presently available. While SGS-THOMSON is 
most likely in possession of the largest collection 
of battery life data of this kind in the world, the re- 
sults presented should not be considered absolu- 
te or final; they can be expected to change as yet 
more data becomes available. We believe that 
future read points of life test presently under way 
and improvements in the battery technology itseif 
will result in a continuing improvement of these 
figures. 


Two end of life curves are presented in Figure 9. 
They are labeled “Average” (tsqqq) and (ty9,). The- 
Se terms relate to the probability that a given num- 
ber of failure will have accumulated by a particular 
point in time. If, for example, expected life at 70°C 
is at issue, Figure indicates that a particular 
MK48TO8 has a 1% chance of having a battery fai- 
lure 11 years into its life and a 50% chance of fai- 
lure at the 20 year mark. Conversely, given a 
sample of device, 1% of them can be expected to 
experience battery failure within 11 years; 50% of 
them can be expected fail within 20 years. 





Leen 


The tyo, figure represents the practical onset of 
wear out, and is therefore suitable for use in what 
would normally be thought of as a worst-case ana- 
lysis. The ts50% figure represents ‘‘normal"’ or 
“average” life. It is, therefore, accurate to say that 
the average device will last “‘tso%’- 


Battery life is defined as beginning at the date of 
manufacture. Each MK48T08 is marked with a four 
digit manufacturing date code in the form YYWW 
(example: 8625 = 1986, week 25). 
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Calculating Predicted *‘Storage Life of the 
Battery © 


As Figure 9 indicates, the predicted Storage Life 
on the battery in the MK48T08 is a function of tem- 
perature. 


Because the ambient temperature profile is depen- 
dent upon application controlled variable, only the 
user can estimate predicted Storage Life in a gi- 
ven design. As long as ambient temperature is held 
reasonably constant, expected Storage Life can be 
read directly from Figure 9. If the MK48T08 spends 
an appreciable amount of time at a variety of tem- 
peratures, the following equation should be used 
to estimate Storage Life. 


Predicted Storage Life= 1+ ([(TAi=TN)+ SL4] + [TA2+ TT) +SLa]+...+ [TAN +17) + SLN}) 
Where TA;, TAz, TAN, = Time at Ambient Temperature 1, 2, ect 


TT = Total Time = TA; +TA2+...+ TAN 


SLi, SL2, SLy= Predicted Storage Life at Temp. 1, Temp. 2, ect. (See Figure 9) 


ee ee nae al 


Example Predicted Storage Life Calculation 


Acash register/terminal operates in an environment 
where the MK48T08 is exposed to temperatures of 


30°C (86°F) or less 4672 hrs./yr.: temperatures 
greater than 25°C, but less than 40°C (104°F), for 
3650 hrs./yr.; and temperatures greater than 40°C, 
but less than 70°C (158°F), for the remaining 438 
hrs./yr. 


Reading Predicted ty values from Figure 10; SL1= 456 yrs., SLo= 175 yrs. SLg= 11.4 yrs. 


Total Time (TT) =8760 hrs./yr. TAy = 4672 hrs./yr. TA = 3650 hrs./yr. TAg = 438 hrs./yr. 


Predicted Typical Storage Life =1 + {{(4672 +8760) + 465] + [3650 + 8760) = 175] + [(438 + 8760) = 1 1.4]} 


Predicted Typical Storage Life = 126 years 
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ABSOLUTE MAXIMUM RATINGS* 


Voltage On Any Pin Relative to GND -0.3 V to +7.0V 
Ambient Operating (Voc On) Temperature (Ta) —“—s—sSCSCSCSCCi td. + 70° 
Ambient Storage (Vcc Off, Oscillator Off) Temperature 20°C to + 70°C 
Total Device Power Dissipation __ 1 Watt 


Output Current Per Pin ee 20 mA 


* Stresses grater than those under “Absolute Maximum Rating” may cause permanent damage to the device. This is a stress rating only 
and functional operation of the device at these or any other conditions beyond those indicated in the opertional section of this specification 
is not implied. Exposure to absolute maximum tating conditions for extended periods of time may affect reliability. 





RECOMMENDED DC OPERATING CONDITIONS 
(0°C < TA <= +70°C) 


SYMBOL | PARAMETER | max | UNITS NOTES 
















OC ELECTRICAL CHARACTERISTICS 
(0°C < TA < + 70°C) (Voc (Max) < Voc <Vcc(Min)) 


SYMBOL | PARAMETER | win max. | UNITS NOTES 
pee fm | 














Output Logic ‘‘1" Voltage (Ioyt = — 1.0 mA) 
Output Logic “0” Voltage (Igy7 =2.1 mA) 
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Pin Description 


Symbol 


Type 
/O/BD - cell 


Revision 1.0 


Description 


ee 


IU Interface 


iu_clk 
ctl 


SBus Interface 


sb_br_ 
sb_bg_ 
sb_as_ 
sb_siz(2:0) 
sb_ack8_ 
sb_ack32_ 
sb_err_ 
sb_merr_ 
sb_rd 
sb_a(4:0) 
sb_d(31:24) 
sb_reset_ 
b_irq(7:1)_ 
mb_irq_ 


MMU 


io_sel_ 
type (1:0) 
B_A31_29L 
B_A28_26L 
B_A25_24L 
pa(28:20) 
pai9_16H_ 


Misc 


pur_ 
gen_por_ 
ureson_ 
uresoff_ 
sysclkxin 
sysclkxout 
sloti_ 
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| - DRVT8 
Input- TLCHT 
cycles. 


O - BT4 

1 - TLCHN 
| - TLCHN 
BD - BD4TU 
BD - BD4TU 
BD - BD4TU 
BD - BD4TU 
| - TLCHT 
BD - BD4TU 
1 - TLCHT 
BD - BD4TU 
| - TLCHN 
O - BT10D 
O - BT10D 


1 - TLCHN 
| - TLCHT 
| - TLCHN 
| - TLCHN 
| - TLCHN 
| - TLCHT 
| - TLCHT 


| - TLCHT 
O - BT1 

| - TLCHT 
| - TLCHT 
1 - OSCIM 
O - OSCIM 
| -TLCHN 


Integer Unit Clock.Main system clock. 
Atomic load-store indication during device 


S-bus Bus request. 

S-bus Grant. 

S-bus address strobe 

S-bus Size. 

S-bus 8-bit Acknowledge. 

S-bus 32-bit Acknowledge. 

S-bus Error. Failed transfer. 
S-bus Late Error. Failed transfer. 
S-bus read, High for Read cycles. 
S-bus Address bits 4-0. 

S-bus data. 

S-bus reset. 

S-bus interrupts = VME interrupts 
Interrupt Request for mail box interrupt. 


Non-type 0 space strobe. 
MMU type bits. | 

Decoding of P1_A(31:29) 
Decoding of P1_A(28:26) 
Decoding of P1_A(25:24) 
Physical address bits. 
Decoding of pa(19:16)= OxF. 


Power-up reset 

Generate Power on reset. 
User reset on 

User rest off 

Xtal in, VME system clock 
Xtal out VME system clock 
Slot Indicator. 
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Master Interface: 


A full 32 bit Master Interface is provided. Complete mapping of 51 2 MByte is possible all the 
time, but this 512 MByte window can be moved through all 4 GByte through a VME Mapping 
register. 


A32, A24, A16 Address Modes, D32, 016, D8(EO) Data Sizes are supported. . 


On Master cycles, RMW, i.e. atomic load-store cycles are implemented according to the 
VME spec. The VME data strobe will be asserted two times as the VME address strobe is 
asserted. This differs from other Sun boards, where instead the ownership of VME is kept 
while a read anda write takes place. The problem with this is that if the access is to a board 
with several devices competing for an onboard bus, there is no way this board can 
recognize the access as a RMW. For example.: a disk board with multiple on board devices 
would not be able to prevent a shared resource to be stolen in between what looks like a 
standard Read and Write even though the VMEbus is hold. 


Block mode transfers are not supported. They are only supported by the Slave interface. 


Unaligned transfers (UAT) are not supported. Accesses of this kind, i.e. 16-bit accesses to 
base addr. + 1 or addr. + 3, or 32 bit accesses to base addr. + 1, base addr. + 2 or base 
addr. + 3 will not be recognized, resulting in a Bus error time out. 


A32 Map Register 


Type Device Addr Device Physical Space 
“4 OxEFE00018 A32 Map Reg. 1 byte 


at 30 29 28 27 26 25 24 
oe 


This register can re-map VME Address bits A[31 :29] to enable full 4 Gbyte mapping. Only 
8-bit accesses should be used, 16- or 32-bit accesses will not be acknowledged, resulting 
in a bus error time out. 


Initialization: The register will be cleared to 0’s on resets, thus 
mapping the 512 MByte MMU mapping to 0-512 MByte 
and disabling loopback mode. 


Bit: , 

31:29 OxO0 map VME Master range Ox00000000-Ox1FFFFFFF O-512 MByte 
Oxi = ° = * 0x20000000-0x3FFFFFFF 512-1 GByte 
2S Se * Ox40000000-OxSFFFFFFF 1-1.5 ” 
Og =- * = * Ox60000000-Ox7FFFFFFF 1.5-2 ” 
Oxf = * = * Ox80000000-OxSFFFFFFF 2-2.5 “ 
0x5 = e! = * OxA0000000-OxBFFFFFFF 2.5-3 ”* 
6x6 2 - © “Suya OxCOO000000-OxDFFFFFFF 3-3.5 ”° 
Ox? = OxEOO00000-OxFFFFFFFF 3.5-4 ” 

28:25 Not used, always read back as 0 

24 This bit set will enable VME loopback mode, used for diagnostics. 
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Slave Interface: 


A32, A24 address mode. 


1 MByte of memory is accessible, normally the lowest MByte on VME, but this can be 
changed to be in the 1-16 MByte range to support multi CPU board implementations. The 
address range will be incremented in 1 MByte steps. 


VME defined Read-Modify-Write cycles is guaranteed to be atomic with respect to other 
VME Masters. Atomicity between VMEbus Slave accesses and CPU/Ethernet accesses to 
main memory, however, is not guaranteed. To guarantee this, the VME Bus Locker should 
be used, see the section about the Bus Locker register. 


Unaligned accesses to the Slave Interface range will return a Bus Error back to the external 
VME Master. 


The address modifiers on VME are used to define Address mode (A32/A24/A16), Privilege, 
and data/program/block-transfer access. The Slave decoder and Mail Box interrupter will 
monitor all address modifier bits with the exception of AM2, the access privilege bit. All 
slave accesses as a DVMA device will be set to supervisor mode, which is in accordance 
with the Sun-4 Architecture. 


The 1 MByte VME address space selected will always be mapped to the highest megabyte in 
the Virtual Address Space, again in accordance with the Sun-4 Architecture. 


Single Transfers/Block Mode Transfers 


The DMA enable bit in the System Enable Register can disable SDVMA and therefore all 
Slave cycles. If this bit is set, single slave cycle can take place. 


Block Mode transfers are enabled if the corresponding bit in the Slave Map Register is set. 
Only blocks of 4 transfers of aligned 32-bit words are supported. Longer blocks will result in 
a Bus Error from the fifth transfer and on. Accesses with other data sizes will get a Bus Error 
returned. 


Slave Map Register 


Type Device Addr Device Physical Space 
1 OxEFE0001C SMAP Reg. 1 byte 


29 28 24 


31° 30 27 26 25 
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The address space for System DVMA accesses is 1 MByte, normally the lowest Megabyte in 
accordance with the Sun-4 Architecture, but bits 28:25 can be used to re-map the SDVMA 
address space. Slave Block Mode transfers can also be enabled by setting bit 31. This 
lowest 1 MByte on VME is mapped to the highest 1 MByte within the Virtual Address space. 
During register accesses, only 8-bit accesses should be used. 16- or 32-bit accesses will 
not be acknowledged, resulting in a bus error time out. 


Initialization: The register will be reset to all 0's on resets. 
Thus, the mapping will default to 0-1 MByte and block mode 
transfers will be disabled. 


Bit: 

31: This bit set will enable Block Mode Transfers. 

30:28 Not used, read back as 0 

27:24 OxO0 map SDVMA space to 0x00000000-Ox000FFFFF 0-1 MByte 
Ox1 - " - * 0x00100000-OxO01FFFFF 1-2 ” 
Ox2 - " - " 0x00200000-Ox002FFFFF 2-3 ” 
Os = “ = ? 0x00300000-Ox003FFFFF 3-4 ” 
Ox4- " - * 0x00400000-Ox004FFFFF 4-5 ” 
Oxs - " - " Ox00500000-Ox005FFFFF 5-6 ” 
Ox6 - " - * Ox00600000-Ox006FFFFF 6-7 ” 
Ox7 - ”" - * O0x00700000-Ox007FFFFF 7-8 ” 
Ox8 - " - ”" Ox00800000-OxO08FFFFF 8-9 ” 
Ox9 - " - * Ox00900000-Ox009FFFFF 9-10 ” 
OxA - oe ee ke OxO00A00000-OxO0AFFFFF 10-11 ” 
OxB - ”" - ” OxO00BO0000-OxO00BFFFFF 11-12 ” 
Oxc - " - * Ox00CO00000-Ox00CFFFFF 12-13 ” 
OxD S4ao% moc OxOO0DO0000-Ox00DFFFFF 13-14 ” 
OxE - ”" - * OxO00EO0000-Ox00EFFFFF 14-15 ” 
OxF - " - *" OxO0OFOO000-OxOOFFFFFF 15-16 " 
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Mail Box 


A Mail Box interrupt function is provided. This mail box interrupt will detect accesses to the 
A16 address space to a location Programmed into the mail box register. No real memory is 
Provided at the location, but the mail box will respond with a VME DTACK, acknowledging 
the access and generate an on board interrupt if the Enable bit is set. VME Address bits 
A(15:14, 3:1)) will be checked and compared to the contents of the bits in the Mail Box 
Register. This corresponds to Programming the location to one of the first 16-bit words at 
one of the four 16 KByte blocks of the address range. Any VME A16 address space, 8-bit or 
16-bit read or write to the location Programmed into the Mail Box Register will generate an 
onboard interrupt on level 8 if enabled. 32-bit wide access are not allowed and will not be 
acknowledged, resulting in a Time out Bus Error for the other accessing VME Master. 


48-64 KByte 
32-48 KByte 
16-32 KByte 
0-16 KByte 





Mail Box Register 


Type Device Addr Device Physical Space 
1 OxEFE00010 Mail Box Reg. 1 byte 


31 26 25 24 


30 29 28 27 


This register will set the VME address that will be monitored and will, if enabled, interrupt the 
IU via an on-board interrupt. Only 8-bit accesses to the register should be used, 16- or 
32-bit accesses will not be acknowledged, resulting in a bus error time out. For mail box 
cycles, the VME bus will only be monitored for A16, 08 or D16 accesses. 


Initialization: All bits will be initialized to 0's. 


S4-VME 9/21/89 Page 10 


Revision 1.0 





Interrupt: level 1. 


Bit: Note 

31 This bit set indicates that a mailbox interrupt is pending. A read of this register will 
reset the interrupt on the trailing edge of the read pulse. A write to this bit is ignored. 

30. ~=‘This bit set will enable the mail box interrupt. 

29 This bit is ignored, read back as 0 


28 To compare with VME Address bit 15 
27 - e - . 14 
26 - : - ” 3 
25 “ = - : 2 
24 - . a, 1 
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VME Bus Locker 


A Bus locker function is provided to enable the CPU to do an atomic Read-Modify-Write 
(RMW) to its onboard memory without interrupting an incoming RMW from the VME Slave 
interface. This function is only to be used when the board is running together with one or 
more external CPU boards(Multiprocessing). In these cases, message passing is done 
through shared memory locations that need to be accessed in a defined way. 


VME Bus Locker Register 


In a Non-Multiprocessing application, this register should be left alone. When used, bit 24 of 
the register should ALWAYS be SET for each update, to guarantee a consistent bus 
arbitration behavior. 


Type Device Addr Device Physical Space 
1 OxEFE00000 Bus Locker. Reg. 1 byte 
31 30 29 28 27 26 25 24 
foe] 2 Te [Te Te [2 Preven] toa 
Initialization: All bits will be initialized to O's. 


Thus, the VME bus locker will be inactive and not affecting the 
board’s bus arbitration. 


31 This bit indicates that the VME Bus is owned. No external VME board can access 
memory. Bit is read only, a write to this bit will be ignored. 
30 This bit is ignored, read back as 0. 


29.2=«C« - -— § « Hy 
SBS 2 8 ae Fw FF we Be 
f= * ye e Bt we we 
a = = a2 * oa * we He 


25 This bit initiates a VME Bus request. Once owned, it will be held. 

24 This bit set will enable the Bus request function. It should only be set for multi- 
processing applications. If set, it should never be changed (unless system is 
restarted). 


In multiprocessing applications, update register at system initialization time by writing 0x01 
to the register.The procedure for accessing an onboard memory location is: 

1 Disable VME Interrupts to prevent deadlock. (VME Interrupts need to acquire VME) 
2. Request VME bus locking by writing 0x3 to the register. 

3. Read register and check bit 31 to until VME bus is owned and locked. 

4. Do RMW (atomic Load-Store) to onboard memory. 

5. Unlock VME by writing 0x1 to register. 

6. Enable VME Interrupts 

Thus bit 24 is kept set. 


Note ! Note that if VME is not unlocked in time, other accesses might time out Causing a 
system crash. Always unlock VME ASAP after the RMW is completed ! 
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Interrupt Handler 


The interrupt handler can selectively support all interrupt levels. These are enabled through 
the VME Interrupt/Bus Arbiter register. Note that this register is a replacement for a jumper 
and should normally be fixed depending on the VME Interrupt handler configuration. 
Run-time enabling of the interrupts are normally done with the Interrupt Enable register, see 
the System Specification. 


Single level arbitration is normally used. If some VME boards do not get enough access to 
the bus, round robin select can be used. In that case the arbiter will give equa! priority to all 
four levels. See the VMEbus spec. 


Interrupt Enable/ Bus Arbiter Mode Register 


The Interrupt Enable Register can selectively enable all VME interrupt levels. 


Type Device Addr Device Physical Space 
1 OxEFE00014 VME Int. Reg. 1 byte 


31 30 29 28 27 26 25 24 
Pens Tove ]ins [eve [et [mae 


This Register enables VME interrupts to be fed to the Interrupt logic in the S-4 MMU chip. 
This register replaces 8 jumpers on the board. Only 8-bit accesses should be used, 16- or 
32-bit accesses will not be acknowledged, resulting in a bus error time out. 


Initialization: bits 31:25 will be set and bit 24 reset. 
Thus, VME interrupts will be enabled and the arbiter mode will be 
SGL, single level arbitration. 


Bit: 

31 This bit set will enable VME Interrupt 7/Sun-4 level 13 to Int.logic 
56 «= © = = = © = * = Gf “ = 1 = 

29 = ££ ie Fe @ = = = Ble * = BF = 

28 = © = * = © we * & Geo * = Oye 

27 a 8 ae we 8 oe Ne Bia * = Ss = 

26 =o © & © el pero ney benign Sng Gow Fy 

25 se i ee a * oe Fe = a? = 2 = 


24 This bit set will set the bus arbiter into a RRS mode (Round Robin Select). 
This bit reset will set the bus arbiter into a SGL level bus arbiter (arbitration level 3 
only). 
Note that enabling of the bus arbiter function is done via a jumper (Slot1 jumper). 


Note! This register replaces onboard jumpers. Changes to this register should only be done 
at system initialization time not to be changed later (unless system is restarted). 
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VME IACK Cycles 


Interrupting devices out on the VMEbus require an interrupt acknowledge cycle to obtain an 
interrupt vector. A device space operation is used by the interrupt handler to run the 
acknowledge cycle and obtain the vector. The operation is Device space byte read with 
A[3-1] set to the VMEbus interrupt level being acknowledged. This location should only be 
accessed with 8-bit reads, 16- or 32-bit accesses will not be acknowledged, resulting in a 
bus error time out. 


Note that an access to these seven addresses are not to an on chip register, but instead to 
execute a VME Interrupt Acknowledge cycle, acquiring the Interrupt Vector from the 
interrupting device. 


Type Device Addr Device Physical Space 

1 OxEFE00000 VME Int.Vector A[3:1J=VME Int. level, 
AO=1, Read, only 8-bit 
accesses should be _ used. 


31 30 29 28 27 26 25 24 


8-bit Interrupt Vector from interrupting VME Device Level A(3:1) 


This translates into the following interrupt responses: 


Acknowledging VME interrupt Device Address 
1 OxEFE00003 
OxEFE00005 
OxEFE00007 
OxEFE00009 
OxEFE0000B 
OxEFEO000D 
OxEFEOOOOF 


NOOO FW A 


initialization: Not applicable. 


JACK Daisy Chain Driver 


Active if Board is located in slot one, indicated by the Slot1 jumper. 
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Bus Requester 


The Bus requester is an ROR requester. It releases the bus when other VME 
Masters/Requesters requests the bus. 


Bus Arbiter 


Two types of arbiters are provided, a Single Level Arbiter or @ Round Robin Select Arbiter. 
They are selected through the VME Interrupt/Bus Arbiter register. Note that the arbiters will 
only be enabled if the board resides in slot 1. (Slot1 jumper) 


In arbitration mode, locked arbitration will be detected and released by the arbiter after 3.3 
ms. The Bus arbiter will then drive BBSY active for the minimum period required by the 
VMEbus spec. This is to prevent requesters that in the mean time have decided to withdraw 
their requests to be able to do so. Note that a withdrawal of a VME Request normally is in 
violation of the VME Specification. (Rule 3.11) 


Bus Time Out Period 


There are two time out parameters in a VME cycle in addition to the On Board Bus arbitration 
timer: Rerun Time Out and Abort. 


Rerun time out: If the time from the Master cycle starts until the VME slave responds with a 
DTACK exceeds 1.6 us, the cycle will be rerun by the IU so high-priority devices can get on 
the Sbus. In the mean time, the Master cycle and all output signals will be frozen, ignoring 
any DTACK coming in. When the cycle is rerun it will be reconnected again. 


Abort: Two stages of the access exists. If the bus is not owned, it has to be acquired. Then 
the actual VMEbus cycle can start. A Master cycle will time out after 300 us. That means, 
the response time from another VME slave including the time for acquiring the bus must be 
less than 300 us. 


If the VMEbus is not owned when an abort occurs, the bus requster will keep the VME Bus 
Request asserted even though the CPU cycles has been aborted. It will then assert a 
dummy Bus Busy (BBSY) when the Bus Grant is received. This is to comply with VME rule 
311. 


If the bus is owned when the abort takes place, a Bus Error will be generated. This Bus Error 
would normally be generated by an accessed VME slave. This is to comply with VME rule 


2.48. 


System Reset 
On power up, the CPU board will generate SYSRESET for a minimum of 200 ms, if the Slot1 


jumper indicates the boards resides in slot 1. Incoming VMEbus resets will always generate 
an on board reset. 
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Jumper 


Only one jumper is required for the VME Interface: Slot! . thereby replacing numerous other 
jumpers. These other settings will be defined be by software register settings. 


Function "slot 1” position "not in slot 1” VME 
SYSTEM CLOCK enabled tri-state 
VME IACK Daisy-chain Driver enabled IACKIN drives IACKOUT 
SYSRESET Sb_reset will generate sb_reset will not 

VME SYSRESET. generate VME SYSRESET 
BUS ARBITER enabled (type deter- disabled 


mined by disabled 
Interrupt reg bit 0) 


Programmable settings 


The following registers include settings otherwise often provided by jumpers. 


Slave Map Register Defines the memory address space of the 
IMByte on board VME Slave (System 
DVMA). 

VME Interrupt Handler Register Defines which interrupt levels to handle. 


Defines what type of VME Bus arbiter (If 
board resides in slot 1) 


A32 Map Register Defines where to map the CPU Master 
Address Space of 512 MByte. 
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Performance: 


The VME Gate Array logic will be designed to meet the Sbus and VMEbus specifications at a 
20 MHz clock, correlating to a 50 ns clock cycle. 


Bus arbitration for other VMEbus masters will take place faster thanks to the Early Release 
feature. 


System DVMA can offer a higher bandwidth with the VME Block Mode transfer. 


Note that these numbers are given only as a way to describe the VME performance. Since 
the overall bandwidth depends on the other board’s response time, the application code, 
amount of other tasks running concurrently, other concurrent DMA activity, cache hit/miss 
ratio etc. these figures should NOT be expected to on a running system. 


Master Cycles 


Conditions: Ideal VME slave accessed (30 ns DS to DTACK response). Bus already owned. 
No lingering DTACK or AS. 


A Master cycle will be 9 cycles, corresponding to a theoretical 9 MByte/s bandwidth for 
back-to-back cycles. 


Slave Cycles 


Conditions: Ideal VME master (0 ns DTACK to DS response). Fast Sbus grant (two clock 
periods). 


Cycle duration [ns] theoretical bandwidth 
Single read 560-630 ns 6.9-7.9 MByte/s 
Single write 510-580 ns 6.3-7.2 MByte/s 
Block read 950-1250 ns 12.7-17.7 MByte/s 
Block write 920-1160 ns 13.7-17.4 MByte/s 
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Bus Arbitration 


Single level Arbiter: 
Conditions: No VME master owns the bus, Bus Locker disabled. 


VME Bus Request to VME Bus Grant: 2 Cycles 
Conditions: No VME master owns the bus, Bus Locker enabled 
VME Bus Request to VME Bus Grant: 3 Cycles 


Round Robin Arbiter: 
Conditions: No VME master owns the bus, Bus Locker disabled. 


VME Bus Request to VME Bus Grant: 2-5 Cycles 
Conditions: No VME master owns the bus, Bus Locker enabled 


VME Bus Request to VME Bus Grant: 3-6 Cycles 
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Timing Specification 


Conditions: VCC=4.75 to 5.25 V, TRA = 0 - 70 C, Output load = 130 pF 


Symbol From To (note1) Min Max unit Note 

RS 
Sbus signals 

t1 clk high clk high 50 50 ns 

t2 clk high sb_ack valid 3 33 ns 2 

3 clk high sb_d valid 3 34 ns 

t4 clk high sb_rd valid 3 30 ns 

15 clk high sb_siz valid 3 26 ns 

t6 clk high sb_br_ 3 24 ns 


JACK Daisy Chain 


t7 pi_ds(1:0)_ ass. vme_iackout ass. 43 155 ns 3,7 

t8 pi_as_ neg. vme_iackout neg. 15 ns 3,7 
Requester/Arbiter 

to clk high vme_bbsy_ 26 ns 

t10 ~— clk high vme_bgout 25 ns 

t11 clk high vme_br 25 ns 

t12 ~~ clk high b_asen_ ass. 29 ns 

t13. clk high b_asen_ neg. 38 ns 

t14. vme_as_neg. b_asen_ neg. 12 ns 
Master 

t15 ~~ clk high vme_am 28 ns 4 

t16 ~— clk low vme_as ass. 21 ns 

t17 clk high vme_as neg. 25 ns 

t18 = clk low vme_ds ass. 23 ns 

t19 clk high vme_ds neg. 20 ns 

t20 ~—sclk high ma_aclk 24 ns 

t21 clk high ma_aen_ 19 ns 
Slave cycles 

t22 ~~ clk high sl_aclk 23 ns 

t23. clk high s|_aen_ 14 ns 

t24 ~— clk low SbtPiclk 6 19 ns 

125. — clk high PitSbclk 21 ns 

126 ~—s clk high PitSben_ 20 ns 
Slave single cycles 

t27. clk high vme_dtack 20 ns 

{28 clk high vme_berr 20 ns 
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t29 clk high SbtPien_ 20 - ns 
Slave Block Mode Reads 
30 P1_DS_ ass. vme_dtack_ 37 719 ns 7 
131 Pi_DS_ ass. vme_berr_ 37 719 ns 7 
132 Plen_ ass vme_dtack_ ass. 28 103 ns 7 
33. =Plen__ neg vme_dtack_ neg. 30 108 ns 7 
134 P1_DS_ ass. SbtP1en_ ass. 8 616 ns 7 
35 Pi_DS_ neg. SbtPien_ neg. 6 28 ns 7 
t36 P1_DS_ ass. pl_sel valid 6 29 ns 7 
Slave Block Mode Writes 
137. +P1_DS_ ass. vme_dtack_ 35 659 ns 7 
t38 P1_DS_ ass. vme_berr_ 35 659 ns 7 
139. P1_DS_ ass. PitSbclk 7 37 ns 7 
t40 ~—s clk high PitSben_ 5 15 ns 
t41 clk high pl_sel valid 20 ns 
misc. VME 
t42 vme_sysr_ ass. vme_sysr_ neg. 200 ms 5 
Setup time 
sbus signals, ctl1, type(1:0) 15 ns. 6 
pa(28:20) 23 ns 
DB_axx_xxl 19 ns 


Hold time for all the above signals is 0 ns except for sb_err_ which is 1 ns. 


1) If signal direction is not specified, both high and low delays are included. 

2) sb_ack: sb_ack8_, sb_ack32_, sb_err_, sb_merr_. 

3) IACK D.C. driver, sloti_ asserted 

4) the clock following sb_as assertion 

5) When chip is in test mode, i.e. P1 _BGIN_.O = low and slot1_ = low the vme _sysr 
counter and the Bus grant counter will be preset to 32 clocks from their max value. 

6) Sbus signals: sb_as_, sb_a, sb 2ck8_, sb_ack32_, sb_err_, sb_merr _sb_rd, sb_siz, 
sb_br_. 

7) This timing is not related to clock 
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Revision History 


3/7/89 First release. 
9/21/89 Revision 1.0 release 


sb_merr_ changed from BD-BD4TU to I-TLCHT (Page 2) 

P1 inputs changed from SCHMITC to SCHMITT (Page 3) 

LSI device type changed from LMA9239 to LIA5530 (Page 4) 
VDD increased from 3 pins to 4 pins (Page 4) 

VSS increased from 4 pins to 8 pins (Page 4) 
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SPARC CPU-2CE Technical Reference Manual 


Section 6 
PROGRAMMING & FIRMWARE MANUAL 
6.0 Programming 


Address Spaces 

Memory Management 

Cache Control 

System Control and Error Handling 
Memory 

Onboard Peripherals 

Interrupts 

LED’s 


6.1 Address Spaces 


The SPARC architecture defines several different address spaces. A user program can 
only access two of them: User Data and User Instruction spaces. When the processor is 
in supervisor mode additional address spaces are available (even beyond the obvious 
Supervisor Instruction and Supervisor Data) using the load and store altemate instructions. 
The User and Supervisor Instruction and Data spaces make up Device space (for memory 
and peripherals). The other ASIs make up Control space, intended for use by system 
functions, such as cache and MMU control. 


6.1.1 Control Space 


The CPU-2CE supports System Space, Segment Map, Page Map, and various cache Flush 
spaces. 
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Table: 6.1 Address Space Indicator Contents nae 

Reserved [Conti space = 
Se 
| System Control Space | 


—— 


System space Control Space System Control Space 
Segment Map Control Space MMU Control Space 
Page Map : Control Space MMU Control Space 


High Speed Segment Flush Control Space Main Memory Cache 
Control Space | 

High Speed Page Flush Control Space Main Memory Cache | 
Centrol Space | 

High Speed Context Flush Control Space Main Memory Cache 
Control Space 


2 












Flush Cache by Segment Control Space Main Memory Cache 
Control Space 

Flush Cache by Page Control Space Main Memory Cache 
Control Space , 

Flush Cache by Context Control Space Main Memory Cache 
Control Space : 

Hardware Virtual Flush Control Space Main Memory Cache 
Control Space 


6.12 System Space (ASI = 2) 


2 


System Space can only be accessed by using load and store alternate instructions while 
the processor is in supervisor mode. It is used to access various System control registers 
as well as for direct access to cache tags and data for diagnostic purposes. 
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Table: 6.2 System Space (ASI=2) 





















ID PROM Not available on CPU-2CE 
Context Register 
System Enable Register 
Bus Error Register 
Diagnostic Register 
Cache Tags 

Cache Data 

Serial Port 













Unused; no timeout 
Diagnostic use 
Diagnostic use 
MMU Bypass 







ID PROM 


The ID PROM is unused on the CPU-2CE. The equivalent function is provided in the 
NVRAM, located in Device Space. 


Context Register 

The Context Register is a 4-bit read/write register which controls which of 16 MMU con- 
texts are in current use. Writes to this register have an immediate effect, subject to the 
normal pipelining imposed by the SPARC processor. The context register should be 
written and read as a byte only. The context Register is cleared on Reset. 

System Enable Register 

The System Enable register controls the cache and SBus as follows: 


Table: 6.3 System Enable Register System Enable Register: ASI=2, 
Address=0x40000000) 





FORCE COMPUTERS 


BOOT/ 0 = All Supervisor References go to EPROM (MMU bypass) 
1 = Normal operation (MMU Enabled) 


Zero Always reads as zero; unused 
DMA_EN 1 = SBus DMA allowed. 
CACHE 1 = Enables cache. (Cache tags should be cleared before enabling) 


RESET 1 = System Reset 
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TLBDis 1 = MicroTLB disabled. For hardware debugging only; should be zero. 


The System Enable register is cleared on Reset, leaving the system in Boot state with 
DMA and cache disabled. 


Synchronous Error Register 
There are six Error Registers in control space: two address and two status registers for 


Synchronous and Asynchronous errors. (In addition to these registers, the parity 
control/status register exists in Device space.) 


Table: 6.4 Synchronous Error Register 


Synchronous Error Register: ASI=2, Address=0x6000 0000 WORD Sc ONLY: 


. ee | 


Table: 6.5 Synchronous Error Register 


Write 1 = Error occurred during a write cycle 


1 Invalid 1 = Valid bit was zero in a page map entry or top 3 adr | 
bits differ. 











| 
i 







q] 


1 = Protection error, write to read-only page, or user 
access Of supervisor-on'~’ page. 


| Timeout 1 = Non-existent device was accessed. 









1 = SBus device returned error-ack (device-dependent). 


1 = Memory (parity) error. (LErr on SBus) See parity 
register 


1 = Restart due to TU error. (Trap while traps 
disabled.) 


In certain circumstances the IU will be given a memory exception which it ignores (such 
as when an annulled instruction falls on an invalid page). In this case, the Invalid error 
bit would be set in the synchronous error register, but the IU did not take a trap. The 
result is that later, more than one bit may be set in the Error Register and software must 
determine which is correct from the address in the Synchronous Error Address Register. 





| 
| § 
g 
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Table: 6.6 Synchronous Error Register: ASI=2, Address=0x6000 0004 WORD 
ACCESS ONLY: 


= "i 
Virtual Address of last synchronous error (A31:0)) | 


The Synchronous error registers will always hold information about the last synchronous 
error which occurred. 









The SEVAR is cleared on power-on or programmer-initiated reset. Synchronous error 
registers are not cleared on a watchdog reset. 


Asynchronous Error Register 


The Asynchronous Error register reports buffered write errors and SBus-Controller detect- 
ed DVMA Enrrors.: 


Table: 6.7 Synchronous Error Register: ASI=2, Address=0x6000 0008 WORD 
ACCESS ONLY: 


= 


Table: 6.8 Synchronous Error Register 

















——— 





Multiple 1 = More than one Async Error since AER last cleared. 
[sper | 1 = IU Writing to a Slave device resulted in an Error Ack. 
= Error during DVMA access. 


1 

1 = SB_AS_ asserted for more than 256 clocks, or DVMA illegal 
adrs. 

| 


[ Proter 1 = DVMA attempted write to read-only page. 


Invalid 1 = MMU Valid bit not set for DVMA access. | 
Copy of IU Size bits for failing writeback operation. 

Error Acknowledges during DVMA are not reported to the IU. It is the responsibility of 

the DVMA master to report errors to the IU. 













Reading the Asynchronous Error register clears it, SB_Reset_clears it. Any asynchronous 
error freezes both Async error registers until read (with the exception of the Multiple bit). 


_ Asynchronous Error Address Register 


(Word access only) 
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Table: 6.9 Asynchronous Error Register : ASI=2, Address=0x6000 0008 WORD ACCESS ONLY: 


j rr Cai T : ; r "I 

| Invalid Timeout Zexo | Zero Multiple 

| 7 4 
Bits 31:10 are read-only ze! 


ad-only zeros. 





Asynchronous Error Data Registers 


Data from the first asynchronous write error since the AER was last cleared is stored at 
ASI=2, Address 0x6000 0010 and 0x6000 0014. Word accesses only, please. These regis- 
ters are cleared on reset. The data at 0x6000 0014 is only valid if the Size code is 11, 
indicating a doubleword store was taking place. Cleared to zeroes on power-on reset, 
software-reset, and watchdog reset. 


Cache Tags and Data 


The Cache Tags are located in ASI 2 with the most significant four bits of the virtual ad- 
dress 8. Tags are unique every 32 bytes for 64K bytes (in other words, there is a 64 K 
Cache, which uses a 32-byte linesize; there are 2K tags). Each tag is 32 bits wide and 
should be accessed only as a full word. Tags are formatted as follows: 


Table: 6.10 Cache Tags 





Cache Data is located in ASI 2 with the most significant four bits of the virtual address 
= 0x9. It is significant for 64K Bytes. 


Serial Port Bypass 


The Serial Port at ASI = 2, Address 0xF000 0000 is intended as an MMU bypass to allow 
the boot PROM to give messages even though the MMU and DRAM are not functioning 
or verified. ; 


Segment Map 


ASI = 3 gives access to the MMU segment map. Only bits 18 through 29 of the address 
are significant in this address space. See the MMU section for details. 


Page Map 
ASI = 4 gives access to the MMU page map. Only bits 12 through 29 are significant in 


this address space (bits 18 through 29 are mapped through the segment map). See the 
MMU section for details. 


a 
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Flush Cache Segment 


A write to an address in ASI = OxC will cause the cache line corresponding to that 
address to be flushed (marked invalid) if: 


e Cache Tag address (29:18) matches virtual address (29:18) and 

¢ [that page is marked supervisor-only or the cache tag context matches the current con- 
text id] 

Flush Cache Page 


A write to an address in ASI = OxD will cause the cache line corresponding to that 
address to be flushed (marked invalid) if: 


e Cache Tag address (29:16) matches virtual address (29:16) 
and 


¢ [that page is marked supervisor-only or the cache tag context matches the current con- 
text id] 


Add Hardware Cache Flushes!! 
Flush Cache Context 


A write to an address in ASI = OxE will cause the cache line corresponding to that 
address to be flushed (marked invalid) if: 


The cache tag context matches the current context and the supervisor-only bit for that 
cache tag is not set. Cache context flushes will not invalidate supervisor-only pages. (All 
supervisor-only pages are assumed to be mapped throughout all contexts.) 


6.13 Device Space 


Device Space corresponds to memory and peripherals. In general, memory is located in 
Type Zero space, on board and SBus IO devices are located in Type 1 space, and VME 
devices are located in type 2 or 3 space, (this space indicator is part of the MMU page 
table entry, and could be thought of as just an extension to the physical address). 


Type Zero Space 

The CPU-2CE supports up to 64 MBytes of DRAM on-board, and up to 128 MBytes with 
the optional SRX board. 

Type One Space 

Type 1 Space contains on-board 10 devices and SBus slots. It is distinguished from Type 


Zero space by the MMU Page Table Entry. By convention all addresses have the MS- 
Address bits are set to 1 (PA28-31.) 


TT 
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Table: 6.11 Type One Space 


Device 

Keyboard and Mouse serial ports 

TTYA and B serial ports 

TOD Clock and NVRAM 

Counter-Timer Registers 

Memory Error Register (Parity) (On-board memory) 
Memory Control Register (On-board memory) 
Memory Error Register (Parity) (Off-board memory) 
Memory Control Register (Off-board memory) 
Interrupt Control Register 

EPROM 

Floppy Controller 

ISDN/Audio chip 

Auxiliary IO register 

SBus Slot Zero (Onboard)* 

SBus Slot One* 

SBus Slot Two* 

SBus Slot Three* 


* All Sbus Slots occupy 25 bits of Address Space. 


Serial Ports 


The serial port controller used for both the Keyboard/Mouse and the general-purpose TTY 
Serial ports is the Zilog 85C30 Serial Communications Controller. For further information 
see the Zilog datasheet. The sub-addresses for the SCC’s are: 


F000 0000 
F000 0002 
F000 0004 
F000 0006 
F100 0000 
F100 0002 
F100 0004 
F100 0006 


Mouse Control Port 
Mouse Data Port 
Keyboard Control Port 
Keyboard Data Port 
TTY B Control Port 
TTY B Data Port 
TTY A Control Port 
TTY A Data Port 


¢ Interrupts occur at level 12. 


* The serial ports use a 4.915 MHz clock as a base for baud rate generation. 


* There is no need for software to provide timing loops between accesses to the serial 
ports. Hardware will guarantee the required recovery time of the SCCs. 


renee 
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TOD/NVRAM 


The Time-of-Day clock and Non-Volatile RAM is implemented in a Thomson Mostek 


MK48T08 RAM with the following address map: 


Note: To insure proper SunOS bootup FORCE uses only 2 Kbytes of the 8 Kbyte chip. 
Through an invertor in a pal, FORCE modifies the base address to be the last 2 Kbytes 


of the NVRAM. A12:13 are inverted on the TOD. 







Table: 6.12 TOD/NVRAM j 
Fr200000 | -NVRAM 
—— 

use | 
[r20007F8 | TOD Control 
[F200 07 —_—_—_—_—| Seconds (00-59) _| 













g 


F2 

[bay 0109 | 
oT 
oT 





AE 
a 


| 






88 


| 
\ 
| 
j 





| 


Ht 
18 





Counter-Timer Registers 


Two 21-bit microsecond resolution counters can provide interrupts at levels 10 and 14. 


They are at the following addresses: 












Table: 6.13 Counters timers 


l = 
Ex 
| 





[F300 0004 ___| Limit 0 Imerrupt Level 10 
[F200.0008 | Coumert 
Limit 1 Interrupt Level 14. 
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* Interrupts are enabled or disabled in the Interrupt Control Register. 
* Each counter starts at a value of “one microsecond” (0x400) 


+ When a counter reaches the value in its corresponding Limit register the Limit bit is set 
(L) and an interrupt (if enabled) is generated. 


¢ The Limit registers initialize on reset to zero. 
* Reading the Limit Register clears its L bit. Reading the Counter does not. 


* Read counters as a word to guarantee that they do not increment during the read. 


Memory Error Registers 


The Parity Control/Status register for the bottom 64 MBytes of DRAM is at F400 0000 


in Type 1 space. The Parity Control/Status register for the top 64 MBytes of DRAM is 
at F400 0008 in Type 1 space: 









| 
|Peror Set on any parity error | 
[2nderror____| Set when party err occurs and PEnor=1__| 
[Pres | sertoimen party frtesing’ | 
[PEnabie | Setto enable checking i 
Set to indicate which byte failed. 


The bits that indicate errors (Perror, 2ndError, Perrn) are cleared when the register is read. 
All bits are cleared on reset. 


Table: 6.14 PError 

















| 
| 
i 


The Perrn bits have the same meaning as on older hardware (note that early older 
documentation was incorrect). 


In word-parity mode, all four Perr bits will be set on any parity error. 
Memory Control Register 


The RAM+ control register is at OxF4000004 in Type 1 space for the on-board DRAM 
and at OxF400 OOOC in Type 1 space for off-board DRAM: 


TT  eeeeesSsS 
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Table: 6.15 Type 1 Space for off Board DRAM 





Dis Ref when set will stop refresh. This is for manufacturing test only. 
Parity when set will use word-wide parity. It should remain cleared on CPU-2CE. 


The Memory Control Register is cleared on Reset. 


Interrupt Control Register 


The Interrupt Control Register is at F500 0000: 






 cieeeaeeaniiiaiaamaat ae J 
| 


‘me = Enable Interrupt Level x. 
SWI: Force interrupt at Level x 
| Master Enable | Set to allow any interrupts. 


z 


| Table: 6.16 Interrupt Control Register 





Clear bit 0, the Master Enable bit, to reset level 15 interrupts. 


Floppy Controller 


The Intel 82072 Floppy Disk Controller is at F720 0000. It should be accessed in byte 
mode only. See the Intel datasheet for details of the register bits. 


F720 0000 MSR (reads), DRS (writes) 
F720 0001 FIFO (reads and writes) 


ISDN/Audio 


The AMD 79C30 ISDN/Audio chip is at F720 1000. See the AMD datasheet for details. 
The ISDN portions of this chip are not utilized on CPU-2CE hardware or software. 


Aux I/O Register 


The Auxiliary I/O register is at F740 0003 as a byte-only device. It has eight bits which 
may be used as inputs or outputs. Only six of these bits are used on the CPU-2CE. To 
use a bit as an input, it should be written as a "1" (it will read back as whatever value is 
driven onto it). This register is set to all 1's on reset. 


Oo 
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Table: 6.17 Aux I/O Register 


LED 1 = Front-panel LED On 

Eject Transition from 0 to 1 to 0 ejects floppy. DriveSel must be set for eject 
to take place. 

TC 1 = Terminal Count. Must be driven for specific amount of time, 
dependent upon floppy data rate. (See 82072 Users Manual for timing 
constraints.) 

DriveSel 1 = Select Floppy Drive. 

DiskChg (Input) Reads as one if drive is selected and no disk is present in the 
drive. 

Density (Input) Reads as one if floppy drive detects high-density floppy inserted. 


(Current floppy drives do not support this signal; software must determine 
density by trial and error.) 


6.2 Memory Management 


The CPU-2CE provides a standard two-level MMU, identical to older designs except for 
sizes and performance. 


* 16 MMU contexts (up from 8 on older) 

¢ 30 Virtual Address bits in 

¢ 32 Physical Address bits out to VME (28 bits to SBus and onboard devices) 
* 256 Page Map Entry Groups (up from 128 on older) 

* 4K Byte Page Size 


° 256K Byte Segment Size 


Figure: 6.1 Ilustration Memory Management 






pale?! 2) 
valid 
writeable 
super-only 
dontcache 







Page Map 






16k x 24 


modified 
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6.2.1 Address Translation 


As long as the system is not in Boot state (system enable register bit 7 not zero), all 
virtual addresses put out by the CPU in Supervisor and User Instruction and Data spaces 
are translated through the MMU. The upper 12 significant virtual address lines, along 
with the current context number, select one of 256 Page Map Entry Groups. This value, 
along with the lower 6 significant virtual address lines, selects a Page Map Entry which 
retums a Physical Address and the permission and statistics bits for the 4KByte page. 


Exception: The lower address bits of EPROM accesses are not translated. The EPROM 
should always be mapped into contiguous virtual memory locations on a EPROM-sized 
boundary. 


6.2.2 Modifying the MMU 


In order to store a new value into the Segment map, simply write a byte to ASI=3. Only 
virtual address bits [29:18] along with the current context ID [3:0] are significant for this 
operation. PMEG values may be read as well. Use only byte loads and stores for 
segment map operations. 


In order to store a new value into the Page map, the segment map must first have been 
initialized for the high-order address bits to choose a Page Map Entry Group in the 
current context. Then a word may be stored to ASI=4 to set the page map value: 


Changing the MMU for a virtual address which was marked cacheable requires that the 
cache be flushed of that address range. 


6.2.3 MMU Protection Criteria 


All Device Space accesses (when the system is not in Boot mode) are subject to address 
translation (with the exception of the EPROM, as listed above), and are subject to MMU 
protection checks. These checks basically validate whether a given access is allowed for 
the current user. Using the bits in the Page Map entry given above, access is allowed if: 


e The V bit is set and 

° The § bit is cleared or the CPU is in Supervisor state and 

The W bit is set or this is a read operation (not a store and not a Idst). 

e The X bit in the Page Map entry is set to cause this page to not be cached. 


° The Type bits are effectively extensions to the physical address; only values of 0 and 
1 are used on the CPU-2CE. 


0- Onboard memory 1- Onboard I/O 
2- VME D16 3- VME D32 


° The A bit is set if this page has been accessed. The bit is cleared by software and used 
in least-recently-used algorithms. 


a 


FORCE COMPUTERS Page 6-13 





Hardware SPARC CPU-2CE Technical Reference Manual 


° The M bit is set if this page has been modified. 2 

In addition, the most significant three virtual address bits must all be one or all be zero, 
or an error will be reported in the AER as a DVMA Timeout, when accessing Type 0 or 
1 Space. 

The statistics bits are not modified in the event of any protection or illegal address viola- 
tions. Accesses which result in Error Ack or timeouts from the SBus will have modified 
their MMU entries as if the access had been successful. 


All DVMA activity takes place in Context Zero as Supervisor. 
6.3 Programming LED’s 


Table: 6.18 LED/SW3 Register (Longword access only) 





CRS CE RIT 
[swoms 
[Swit wer hn eo bea aoe 


2 VME Sysfail* from $4VME | 
asic 

P1_Sysfail* (from p1) Init Enable | 

Sysfail and Abort SW1 | 


25s abort MAR Enable for 32 Bit Mode 
i eee 


Table is from page 17 of the schematics. L is LED 













oo pen 






~ 


1 
‘ 





Page 6-14 FORCE COMPUTERS 


SPARC CPU-2CE Technical Reference Manual Hardware 


SPARC CPU-2CE Technical Reference Manua 


6.3.1 SPARC CPU-2CE LED Programming Example 


Programming examples for CPU-2CE front panel LED’s 


#include <asm_linkage.h> 

#include <cpu_addrs.h> 

#include <mmu.h> 

#include <scc.h> 

#include <map.h> 

#include <misc.h> 

#include <ce_misc.h>(SEE BELOW FOR EXAMPLE OF THIS FILE) 


extern map_memory () 7 
extern unmap_memory () ? 
static byte shadow_reg; /* hold current value of ledsw */ 
/* 
x 


Set and leave LEDs continuously on. 
*/ 

set_leds (pattern) 

byte pattern; 

{ 


byte *ledsw = (byte*) LEDSW_LOC; 
byte temp; 


map_memory(ledsw, LEDSW_PADDR, VW1_ATTRIBUTES, PSI2E); 
shadow_reg &= LEDMASK; /* clear LED field */ 
shadow_reg |= pattern; 
shadow_reg &= ~RUNMODE; /* enable LED function */ 
ledsw[0] = shadow_reg; 
unmap_memory (ledsw, PSIZE); 


/* 
* 
*: 


set_runmode () 
{ 


Set Run-Mode 


byte *ledsw = (byte*) LEDSW_LOC; 
byte temp; 


map memory (ledsw, LEDSW_PADDR, VW1 ATTRIBUTES, PSIZE); 
shadow_reg |= RUNMODE; . 
ledsw[(0] = shadow_reg; 

unmap_memory (ledsw, PSIZE) ; 


/* 
* 
*/ 


byte read_sw() 
{ 


Read the rotary switch. 


byte *ledsw = (byte*) LEDSW_LOC; 
byte temp; 


map_memory (ledsw, LEDSW_PADDR, VW1_ATTRIBUTES, PSIZE) ; 
temp = ~(ledsw[0] >> 4); 

unmap_memory(ledsw, PSIZE) ; 

return. (temp & Oxf); 


i T 
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Example of the ce-misc.h file 


* file: ce_misc.h 


“y 


/* CPU-2CE front panel LED definitions */ 


#define 
#define 


#define 
#define 
#define 
#define 


LEDSW_LOC 0x1f£a00000 


LEDSW_PADDR Ox££000000 /* Slot 3, offset +0x1000000 */ 
LEDMASK Ox0f /* LED field mask */ 

INTENABLE 0x02 /* Interrupt enable: Set/Clear IL15 */ 
RUNMODE 0x08 /* Run-mode: enable LEDS */ 

DIAGMODE 0x00 . /* Diagnostic mode: disable LEDS */ 


6.4 Additional Forth Commands for LEDs/Hexswitch and (Optional Feature Flash 


EEprom) 


These are added to the CPU-2CE OBP: 


1. LEDS/HXSW: 


Cae 


set-diagmode (s=) 
Let user changes mode to DIAGNOSTIC MODE or turn off RUN MODE. 


set-runmode (-- ) 
Let user changes mode to RUN MODE. 


-hexswitch ( -- value ) 
Display value of on board hexswitch. 


leds! ( value -- ) 
Set color combination for front panel LEDs.. Bit combination 
for LEDS is as follows (in Hex): 


00 : Red 01 : Green 10 : Yellow 11 : Blank 
Example: 


Value = LED2 LED1 
00 00 --> 0x0 --> RED RED 
; ( will generate sysfail 


00 01 --> Qxl <--> RED GREEN 
01 01 --> 0x5 --> GREEN GREEN 
11 11 --> OxF --> BLANK BLANK 


-leds ( -- value ) 
Display value of front panel LEDS. 


p2led-on { ==) 
Turn on P2 LED. 


p2led-off ( ==») 
Turn off P2 LED. 


2. FLASH EEPROM: 


aie 


k. 


erase-flash ( -- ) 
Erase Flash EEPROM. 
burn-flash ( bvadr size -- ) 


Given the virtual address of the buffer and the size in-byte of the 
user program, this command will burn that program into the Flash 
EEPROM. 


Senos 
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Section 7 

VME 

7.0 VMEbus Interface 

7.1 Features of the SPARC CPU-2CE VMEbus Interface 


The features of the SPARC CPU-2CE VMEbus interface are listed below: 


° A32/A24/A16 Master (Sun-4 VME Device) and A24/A32 Slave DVMA device as SBus 
DMA device 

° Single-level and round-robin arbitration with bus arbiter timer 

° VME Interrupt Handler with IACK Daisy Chain Driver 

° Clock driver 

° System resetter 

° Full 4-gigabyte VME addressing with mapping register 

° Simple user-setup provided, only one jumper is required (slot one). All other options are 


selected through register settings, stored in EEPROM. 


° A special loopback cycle is provided to enable stand-alone testing of the interface. 

° Watchdog Timer for VME System Bus which issues a VMEbus error. 

° Fair Requester option provides all VME Masters along the bus grant daisy chain with 
equal access to the VMEbus, independent of the Master's slot location. 

° Programmable Mailbox Interrupt Level 

° Adjustable Rerun Counter allows for longer rerun intervals during VME access 

e VME Interrupt Monitor Register provides ability to monitor VME Interrupt lines in real 
time 

e Multiprocessing support with Mail Box Interrupts, programmable slave base address 


ranges, true Read Modify Write (RMW) to local memory and to shared VME resource 
with the use of the VME Bus Locker 


° VME DVMA can be disabled via the DVMA Disable Bit. This can be done without 
affecting the SPARC CPU-2CE’s Ethermet or SCSI ports. 

° Bus Locker provides the ability to perform Read-Modify-Write (RMW) cycles on the 
VMEbus. 
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All of the features listed above (except Watchdog Timer) require SunOS 4.1.1 (or newer). Each of the 
features is optional in that each can be enabled or disabled. 


The Watchdog Timer feature works with any SPARC CPU-2CE-compatible release of SunOS and is 
enabled when the CPU is configured as a Slot 1 Controller. 


The VME Chip includes all VME logic on a 7000 gate CMOS LMAOK 1.5 m-second Gate Array. 
Address and data paths are external, using 29FCT521, 29FCTS2, 29821 and 29FCT821 registers. 
Decoding of VME address A(31:24) is done externally using AS27 gates. Decoding of Physical address 
PA(19:16) is done extemally using an F20. All VMEbus outputs are driven through bipolar drivers using 
A$641, LS04 and F125. 


a_i 
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7.2. VMEbus Basics - An Introduction 


The VMEbus is an asynchronous 32 bit bus, with multi master, multi level arbitration specifying Single 
Cycles, Block Mode Cycles and Read-Modify-Write Cycles. Table 7.1 defines certain conceptual logical 
units. 


Table: 7.1 VME Concept Definitions 


Eee ————— 











accesses Slaves. 


responds with [DTACK/BERR] to Master. 


BUS Requester Requests and keeps the bus on 
order from a Master. 


BUS ARBITERS Grants bus to Requesters through [BG] daisy 
chain. Must be in slot 1. 


——————————— 

















Interrupts bus, responds to Interrupt handlers 
with [DTACK/BERR] and supplies an Interrupt 
Vector. 


Drives [IACKIN/IACKOUT] chain when 
[IACK] and [DS(1:0)] are asserted. Must be in 
slot 1. 


SYS Clock Driver Drives [SYSCLK]. Must be in slot 1. 


| Sysfail is generated by writing red red to the Asserts Sysfail 
LED port. See the LED programming example. | 


} An on card Voltage Supervisor asserts Asserts [SYSRESET]. 
SYSRESET for a minimum of 200 ms after 

| +5V DC has reached 4.5 Volts, if the slot 1 

} jumper is inserted. The ACFAILL is not driven 

| or monitored. Incoming SYSRESET generates 

an on-card reset. 


7.3 VME Performance 


1 Interrupter 








IACK DAISY CHAIN Drive 




































The timing for the VMEbus interface is as follows: 


8 Bit Transfers 1.6 MB per second 
16 Bit Transfers 3.2 MB per second 
32 Bit Transfers 6.4 MB per second 


The VME Gate Array logic meets the Sbus and VMEbus specifications at a 20 MHz clock, correlating 
to a 50 ns clock cycle. 


Bus arbitration for other VMEbus masters takes place faster by using the Early Release feature. 
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NOTE: These numbers are given only as a way to describe the SPARC CPU-2CE CPU performance. 
The overall bandwidth depends on the other card’s response time, the application code, amount of other 
tasks running concurrently, other concurrent DMA activity, cache hit/miss ratio, etc. These figures should 
NOT be expected in a real world system. 

7.4 VME Addresses 

Two Address Modifier bits (AM[5:4]) define three address spaces. 


Table 7.2 shows how these address spaces are defined. 





Three Address modifier bits (AM[2:0]) indicate privilege and type of access: Supervisor, Non-Privileged, 
Program Data or Block Transfer access. Data transfers can be D32/D16/D8 (quad-byte, double-byte or 
single-byte size). Unaligned transfer means that a quad-byte or a double-byte transfer takes place on a 
non-even boundary. Unaligned transfers are not supported by the SPARC CPU-2CE card. 


ee sees 
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Table 7.3 lists the supported VME address spaces. 






Table: 7.3 WME Address Spaces 


Comments 


= 


Al16 Master accesses are possible. 


| 

Taz |____ Maser acess ae possible, 
fois | ___ Master acceses ave possible. 
fpa2 | ___— Master acceses are possible. 


D32 

Al6 Mailbox cycles are monitored 
and can generate the interrupt. 

D8 (only) Mailbox cycles are monitored 
and can generate the interrupt. 


Slave cycles are supported. 


> 


ee 


Slave cycles are supported. | 


ed ee 


7.5 VME Implementation 





The VME Interface adheres to the VMEbus Specification Rev C.1. A later version of the specification, 


released by ANSI, 
rules are: 2.61-68 and 4.49. The SPARC CPU 


the ANSI/IEEE 1014-1987, has changed some optional features to mandatory. The new 
-2CE VME Interface follows all these new rules except for 


2.67 requiring ALL D32 slaves to include Unaligned Transfer capability. The following VMEbus features 


are implemented: 


Single-level VMEbus arbitration (SGL) and round-robin arbitration (RRS). 


A 300 micro-second VMEbus timer. Master cycles time out after 300 micro-second 
generating a Bus Error on VMEbus. This is with onboard master setup in slot 1. 


° Read-Modify-Write accesses to local and VME memory are supported via the bus locker. 


° Unaligned transfers are not implemented nor supported. Unaligned accesses get a Bus 
error returned. Unaligned transfers are 32-bit accesses not to address (1:0)=00 and 16-bit 


accesses not to address (0)=0. See the ANSI/IEEE change described above. 
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° Address only cycles are not decoded, an active data strobe is required for the start of any 
DVMA access. 
° The VME Interface allow Address pipe-lining during Slave accesses, but do not utilize 


the function on VME Master cycles. 


° Early release of bus is possible. Other masters can arbitrate getting bus mastership while 
VME Master access is finishing (Address Strobe still asserted). The VME Interface is 
also prepared for other cards early release of the bus, by awaiting the negation of the 


Address Strobe. 

. The VME Interface requests VME mastership on bus level 3 as an ROR (Release On 
Request). 

° Bus Clear is not monitored. 

° An Interrupt handler that can serve any of the seven interrupts is available. A selection 


of which levels to serve is done by programming a SW register. The Interrupt handler 
is a D08(0), handling only 8-bit interrupt vectors. 


° No Interrupter function is provided. Signaling between CPU cards in multiprocessor 
configurations is done through the Mail Box Interrupt. 
° An IACK Daisy Chain function is provided when the card is in slot one. 
. A System Clock Driver is active, if the card is in slot one. 
e No Serial Clock Driver is implemented. 
«i. An on card Voltage Supervisor asserts SYSRESET for a minimum of 200 ms after +5V 
. DC has reached 4.5 Volts, if the slot 1 jumper is inserted. The ACFAILL is not driven 


or monitored. Incoming SYSRESET generates an on-card reset. 


° Sysfail is generated on the bus by writing red red to LEDs. 


7.6 Major VME Register Groups 


This section lists the major groups of VME registers. The registers can be divided into the following 
groups: 


1. Registers set on system initialization, replacing card jumpers: 
Interrupt Enable Register. 
Interrupts handled. 


Arbitration mode. 


= = a eerste oennnnnenenennnoeesceeeeeey 
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2. Registers used for multi-processing or co-processing: 
Interrupt Monitor Register 
Mailbox Interrupt Register 
Rerun/Mailbox Level Register 
Slave Map Register (also replacing jumper). 
3. Others: 
A32 VME Address mapping. 
Move 512 MB window. 
Enable diagnostic loop back. 
Slave Map register bit0. 
Enable Block Mode transfers. 


Table 7.4 lists the VME registers, their physical base, and size. 


Table: 7.4 VME Registers 





7.6.1 Accesses To Byte Registers 


A byte access to a register involves a data transaction on the eight most significant data lines (D[31:24)). 
The information on the rest of the data lines (D[23:0)) is ignored. This applies to all byte register accesses 
listed in this chapter. 
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7.7 Master Interface 


In compatibility mode a full 32-bit Master Interface is provided. Complete mapping of 512 MB is 
possible all the time, but this 512 MB window can be moved through all 4 GB through a VME Mapping 
register. 


In enhanced mode the additional MMU address bits are supplied to the VMEbus allowing complete access 
to any addresses on the VMEbus. No window limitations exist. 


A32, A24, A16 Address Modes, D32, D16, D8(EO) Data Sizes are supported. 
Master Cycles (RMW) Atomic load-store 


On Master cycles atomic load-store cycles are implemented according to the VME spec. The VME data 
strobe asserts two times as the VME address strobe is held asserted. This differs from other Sun cards, 
where instead the ownership of VME is kept while a read and a write takes place. The problem with this 
is that if the access is to a card with several devices competing for an on-card bus, there is no way this 
card can recognize the access as a RMW. For example: a disk card with multiple on card devices would 
Not be able to prevent a shared resource to be stolen in between what looks like a standard Read and Write 
even though the VMEbus is locked. 


Block Mode Transfers 
Block mode transfers are not supported. (They are only supported by the Slave interface.) 


Unaligned Transfers 


Unaligned transfers (UAT) are not supported. The following access types are not Supported and result 
in a bus error timeout: 


en 16-bit access to base address plus one or three 

of 24-bit access 

° 32-bit access to base address plus one, two, or three 
° 32-bit access to type two space 


The CPU-2CE can directly map 4 GB with software switch enabled. 


7.7.1 _A32 Map Register Base Location 


This register can re-map VME Address bits A[31:29] to enable accesses to any 512 MByte range of VME 
addresses. Only 8-bit accesses should be used; 16- or 32-bit accesses are not acknowledged, resulting in 
a bus error time out. This register is only needed when Operating the CPU-2CE in compatibility mode. 


7.7.2 A32 Map Register Initialization 


The register is cleared to zeroes on reset, thus mapping the 512 MB MMU mapping to 0-512 MB and 
disabling loopback mode. 


ees 
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Table 7.5 provides a breakdown of the A32 Map register. Table 7.6 provides a breakdown of the A32 
Map register bits. Table 7.7 defines the functions of various bit values. 


Table: 7.5 A32 Map Register 


Physical Space | 


oo ~ | a32 Map | byte | 
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7.73 WME Registers Programming Example 


The following code fragment shows how to handle a VME interrupt. The system interrupt handler, when 
it determines that an interrupt originates on an IU level which corresponds to a VME interrupt, calls one 
of the entry points defined below (_vmelevel1-7). We then attempt to obtain the actual VME vector by 
reading the VME IACK register appropriate to our VME interrupt level. If the vector obtained is a valid 
VME vector, we use the vector as an index into the table "vme_vector.” "Vme_vector" is a table of 


pointers to interrupt handlers for various VME devices. 
/* 
* Handle the 7 levels of VME interrupts: 


* Read the VME IACK register appropriate to 

* the VME level. This will: 

* (1) Perform an interrupt acknowledge cycle 
* (2) Get the VME vector of the interrupting 
= device. 

*/ 


-globl _vmelevell, _vmelevel2, _vmelevel3 
-globl _vmelevel4, “vmelevel5, ~vmelevelé 
-globl _vmelevel7 


_vmelevell: 


set VME_IACK1, %gl ! &gl = address of IACK register 
b _vme_read_ vector ! go read the VME vector 
nop 

_vmelevel2: 
set VME_IACK2, %gl ! %gl = address of IACK register 
b _vme_read_ vector ! go read the VME vector 
nop 

_vmelevel3: 
set VME_IACK3, %gl ! %gl1 = address of IACK register 
b _vme_read_vector ! go read the VME vector 
nop 

_vmelevel4: 
set VME_IACK4, %gl ! %gl = address of IACK register 
b _vme_read _ vector ! go read the VME vector 
nop 

_vmelevel5: 
set VME_IACKS, %gl ! %gl = address of IACK register 
b _vme_read vector ! go read the VME vector 
nop 


_vmelevel7: 
set VME_IACK7, %gl 
b _vme_read_ vector 
nop 


%gl = address of IACK register 
go read the VME vector 


/* 
* This entry is called directly from interrupt. 
big 


_vmelevel6: 


set VME_IACK6, %g1l ! &gl = address of IACK register 
b _vme_read_ vector ! go read the VME vector 
nop 

/* 

* VME interrupt. Do vectoring. 

* The VME vector is read off the VME bus. If this fails (data fault), 

* _trap will check the PC of the fault and jump to _S8purious. 

* 

* The vmelevel# code sets up %gl to contain the address of the 

* appropriate VME IACK register before it branches here. 

*/ 
-global _vme_read_vector 

tdefine VEC_MAX 255 

define VEC_MIN : 64 


_vme_read_ vector: 


ldub {%gl), %16 ! read vector #, acknowledge int. 
cmp %16, VEC_MAX ! check vector limits 

bg spurious _vme 

subcc %16, VEC_MIN, %g3 ! normalize vector 

bl spurious _vme 


eee 
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sll %g3, 2, %g5 ! scale for interrupt counting 
sil %g3, 3, %g3 ! scale vector 
set intrent, %g4 ! per-device interrupt counts table 
ld Ttg5 + %94), %gl { interrupt count 

set vme_vector, &g2 1! table of interrupt vectors 
ine ¥g1 ! count interrupt 

st &gl, [%g5 + %g4) ! and store result 

ld [8g2 + %g3], %g1 1! get handler address 

add &g2, 4, %g2 1 generate address of arg ptr 
ld (eg2 + %g3), %o0 1! delay slot, get arg ptr 

call %gl ! call handler 

d (%00), %o0 1 read arg ptr 


b,a int_rtt ! restore previous stack pointer 
end _vme_read_vector * 


bd 
se 


yme vectors are compatible with the sun3 family in which 
there were possible valid vectors from 64 to 255 inclusive. 
This requires 192 vectors, each vector is two words long 
the first word being the interrupt routine address and the 
second word is the arg. 


Vectors OxC8-OxFF (200-255) are reserved for customer use. 
/ 


* The vme vectoring uses the following table of routines 

* and arguments. The values for the vectors in the following 
* table are loaded by autoconf at boot time. 

® 


@define ERRV  .word _spurious, 0 


~ 
eeee eee et 


seg "data" 
salign 4 
2 
: global vme_vector 
_vme_vector: T vector numbers 
! 


ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
es ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
as ERRV; ERRV; ERRV; ERRV 
3 ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 


! 0x40 - 0x43 scO | sc? 
1 
! 
! 
! 
! 
! 
! 
! 
! 
i 
! 
! 
! 
! 
1 
! 
! 
! 
! 
! 
! 
! 
! 
! 

ERRV; ERRV; ERRV; ERRV : OxA4 
1 
! 
! 
{ 
! 
! 
1 
! 
! 
! 
! 
! 
! 
! 
! 
! 
! 
! 
! 
! 
! 


xdcO | xdcl | xdc2 | xdc3 
Ox4B xycO | xycl | xyc? 
future disk controllers 
0x53 future disk controllers 
0x57 future disk controllers 
Ox5B future disk controllers 
Ox5F future disk controllers 
0x63 tmO | tml | tm? 
0x67 xtcO | xtcl | xtc? 
Ox6B future tape controllers 
Ox6F future tape controllers 
0x73 ec? 
0x77 4e0 | del | ie? 
0x7B future ethernet devices 
Ox7F future ethernet devices 
0x83 vpcO | vpel | vpc? 

? 


vp 
Ox8B mtiO | mtil | mti2 | mti3 
Ox8F SunLink SCP (Systech DCP-8804) 
0x93 Sun-3 zs0 (8 even vectors) 
0x97 Sun-3 zs1 (8 odd vectors) 
0x9B Sun-3 zs0 (8 even vectors) 
Ox9F Sun-3 zsl (8 odd vectors) 
OxA3 future serial 
OxA7? pcO | pel | pe2 | pe3 
OxAB cg2 | future frame buffers 
gpl | future graphics processors 
OxB3 skyO | ? 
OxB7 SunLink / channel attach 
OxBB (token bus) tbiO | tbil | ? 
OxBF Reserved for Sun : 
OxC3 Reserved for Sun 
OxC7 Reserved for Sun 
OxCB Reserved for User 
OxCF Reserved for User 
OxD3 Reserved for User 
OxD7 Reserved for User 
OxDB Reserved for User 
OxDF Reserved for User 
OxE3 Reserved for User 
OxE7 Reserved for User 
OxEB Reserved for User 
OxEF Reserved for User 
OxF3 Reserved for User 
OxF7 Reserved for User 
OxFB Reserved for User 
OxFF Reserved for User 


0x44 
0x48 
Ox4Cc 
0x50 
0x54 


eve 
ooo 
x x 
> ry 
iw 


ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 
ERRV; ERRV; ERRV; ERRV 


: 
: 


eee 
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78 Slave Interface 
The slave interfaces operate in A32 and A24 address mode. 


1 MB of memory is accessible, normally the lowest MB on VME, but this can be changed to be in the 
1-16MB range to support multi-CPU card implementations. The address range is adjustable in 1MB steps. 


Unaligned accesses to the Slave Interface Tange retums a Bus Error back to the external VME Master. 


The address modifiers on VME are used to define Address mode (A32/A24/A16), privilege, and 
data/program/block-transfer access. The Slave decoder and Mail Box Interrupter monitors all address . 
modifier bits with the exception of AM2, the access privilege bit. 


All slave accesses as a DVMA device are set to supervisor mode, which is in accordance with the Sun-4 
Architecture. 


The 1 MB VME address space selected is always mapped onboard to the highest megabyte in the Virtual 
Address Space, again in accordance with the Sun-4 Architecture. 


78.1 Slave Transfer Control 


A bit in the cache System Enable Register can disable SDVMA and therefore all Slave cycles. If this bit 
is set, slave cycle can take place. 


7.82 Slave Map Register 


The address space for System DVMA accesses is 1 MB, nomally the lowest Megabyte in accordance with 
the Sun-4 Architecture, but bits 27:24 can be used to re-map the SDVMA address space. The 1 MB 
address space on VME is mapped to the highest 1 MB within the Virtual Address space. During register 
accesses, Only 8-bit accesses should be used. 16- or 32-bit accesses are not acknowledged, resulting in 
a bus error time out. 


If a slave access occurs to a page within 1 MByte address space that does not have physical memory 
mapped to it then the VME BERR signal will be asserted. Therefore to properly utilize the slave feature, 
the programmer must insure that the slave map iegister is properly set to the correct 1 MByte VME 
address range, and that the physical memory pages are mapped into the DVMA space where Slave 
accesses are expected. 


NOTE: Enabling Slave accesses from VME gives any VMEbus Master access to the entire DVMA virtual 
address range. It is possible that erroneous accesses to this space will affect the operation of the SCSI 
and/or ethemet controllers since their buffers are kept within the DVMA space. 


SS 
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7.8.2.1 Slave Map Register Initialization 


The register is reset to all zeroes on resets. Thus, the mapping defaults to 0-1MB and block mode 
transfers are disabled. 


Tables 7.8 and 7.9 provide more information about the Slave Map Register and bit assignments. 
Table 7.10 defines the bit configurations. 


Table: 7.8 Slave Map Register Address 


Device Address Physical Space | 


Pt 







pe OxEFE0001C Slave Map Register 





Table: 7.9 Slave Map Register Address Bits 


aa | (ES I 


To [ovma] o | o | va stave Address base] 


J 


NOTE: The VME-4 gate array uses bit 30 of the Slave Map Register for DVMA. Bit 30, when set, 
disables any access to the local DVMA by other VME Masters and disables mailbox interrupts. 










= 


7.8.3 CPU-2CE Slave Memory Example 
This example requires a CPU-2CE as a slave board and another VMEbus master that can generate an 


extended address modifier code. To setup a slave window on the CPU-2CE type the following lines of 
code. : 


30 ff700000 100000 map-segments <cr> 
0 obmem 7700000 100000 map-pages <cr> 
0 map-slave <cr> 


The description of the above two lines is as follows: 


<Segment Number> <Virtual Address> <Length> <Map Segments> 
<Physical Address> <obmem> <Virtual Address> <Length> <Map Pages> 


Once these lines are typed in, it is possible to use the slave memory from a master at location 0 using an 
extended address modifier code. 


To verify that the CPU-2CE received the correct data type the following on the slave. 


fff00000 100 dump <cr> 
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Table: 7.10 Slave Master Register Bit Definitions 


| Description VMEbus Address Range | Range 
Start End 








toe This bit is not used and must be 0. 
Lance 
27:24 0x00000000-0000 
27:24 | Ox1 Maps System DVMA Space to: | 0x00100000-Ox001FFFFF | 1MB_ 
2724 | Ox? Maps System DVMA Space to: | 0100200000-0x002FFFFF [2 MB _| 
27:24 0x00300000-0x003FFFFF | 3MB_ | 















i 
| 
5 






N 
~ 


S 
9 
= 
3 
2 
& 
B 
¢ 
3 
5 
Sf 
2 
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12724 | x5 Maps System DVMA Space wo: | oxoosommoo-oxmnsrrrFF [sMB_ | 6 
[2724 7 
[2724 000700000. 1 
[27:24 
| 27:24 
[27:24 
2724 | OxB Maps System DVMA Space to: | 0x00B00000-Ox00BFFFFF | 11 MB | 
[27:24 | oxc Maps System DVMA Space to: | x00C00000-0.00CFFFFF | 12 MB | 
27:24 | 13 MB 
27:24 | 


FEE ERE 





BBE 
i 







| 
3 
| 
i 


NTN 








eee 


} 27:24 | OxD Maps System DVMA Space to: | 0x00D00000-0x00DFFFFF 
0x00F00000-0x00FFFFFF 






| 
1 


: 





7.9 Mail Box 


A Mail Box interrupt function is provided to allow other devices to interrupt the SPARC CPU-2CE. This 
mail box detects accesses to the A16 address space to a location programmed in the mail box register. 


No real memory is provided at this location, but the mail box responds with a VME DTACK, 
acknowledging the access and generate an on card interrupt Level’ {3 if the Enable bit is set. VME 
Address bits A(15:14, 3:1) are in the Mail Box Register. This corresponds to programming the location 


_ -_.  rr  ———————— eeeee 
Page 7-14 FORCE COMPUTERS 


Hardware 


SPARC CPU-2CE Technical Reference Manual 


to one of the eight 16-bit words in one of the four 16K blocks of the address range. Any VME A16 
address space, 8-bit or 16-bit read or write to the location programmed into the Mail Box Register 
generates an on-card interrupt on level 13 if enabled. 32-bit wide accesses are not allowed and will not 
be acknowledged, resulting in a Bus Error Time out to the accessing VME Master. 


Since the address mapping of the location monitor compares only the address bits A15, Al4 and A3, A2, 
Al (Bits A13 up to A4 are NOT compared at all), the location monitor address is mirrored 1023 times 
in the selected 16K range. The user is advised to use addresses with address bits A13 to A4 set to zero. 
7.9.1 Mail Box Register Base Location 

This register is used to program the VME address to be monitored and, if enabled, mailbox interrupts the 
IU via an on-card interrupt. Only 8-bit accesses to the register should be used, 16- or 32-bit accesses are 
not acknowledged, resulting in a bus error time out. For mail box cycles, the VME bus is only eee 
for A16, D8 or D16 accesses. 

7.9.1.1 Mail Box Register Initialization 


All bits are initialized to zeroes. 


Tables 7.11, 7.12, and 7.13 provide more information about the meaning of the Mail Box Register and 
.._ its bits. 


Table: 7. 11 Mail Box Register Address 


ae Mail Box Regiser_[ 


Table: 7.12 Mail Box Register Address Bits 


Sn 
[ise | ent [0 | comp address 15:14) | Comp Adaress (1) 


7.9.12 Mail Box Register Interrupt Level 













eae 






i 





SPARC CPU-2CEs have programmable interrupt levels of 2, 3, 5, 8, 9, 11, and 13. 
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A read of this register resets the interrupt on the trailing edge of the read pulse. 
A write to this bit is ignored. 


LBL A bi 3] 

[30____| This bit set enables the mail box intemupt, 
[29 | This bits ignored, and is ead backs 
[28 | Compared with VME Address BLS. 
[27 | Compared with VME Address Bit. 
[2s | Compara wit VME Auies Bk SSSCSC~*~*~*S 
[25 | Compared with VME Address Bit, =i 
foe | Compared with VME Address Bit 1. | 






7.10 Mailbox Interrupt Level - Rerun Length Register 


This register sets the interrupt level that a mailbox interrupts on. A default Interrupt level uses pin 
MB_IRQ (level 13 on SBus), but any of the VME interrupt lines, pins B_IRQn, could be used instead by 
setting the appropriate level. Only 8-bit accesses to the register should be used. Accesses of 16 or 32 
bits are not acknowledged, resulting in a bus error time out. 


By default, the Mailbox Interrupt level is set to level 13. On SPARC CPU-2CEs the Mailbox Interrupt 
register (bits 29:31) is used to set the interrupt level associated to the Mailbox interrupt. Then the user can 
program which Processor Interrupt will be generated when a Mailbox Interrupt is initiated. 





Long VME Master cycles (more than 16 clocks) are normally interrupted and frozen. They will be run 
at a later time, letting other SBus masters access the bus. By increasing the value of the rerun counter, 
longer cycles are possible, increasing the chance of getting a VME slave Acknowledgement avoiding the 
delay of a rerun cycle. 


On SPARC CPU-2CEs the VME gate array can be tuned to increase the VME System throughput using 
the Mailbox Interrupt level Rerun Register bits [28:24]. By increasing the rerun interval, you can 
reduce the number of reruns the IU has to perform before an acknowledge is generated by a VME slave, 
increasing VME system throughput. 


ST Ee 
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By default, the rerun interval is set to 16 clocks. For example, it takes 18 clocks to get an acknowledge 
from a slave. If the rerun register is set to 3 (rerun interval is 19 clocks), the TU can finish a VME 
transfer with just one cycle. However, if the default setting is used (16 clocks), it may take at least 20 
to 21 clock cycles (requiring two rerun cycles) to finish the transaction. 


Initialization: All bits are initialized to zero. 


"Bits Note” 


Bits 31:29 = 0 Mail box interrupt on pin MB_IRQ_ or _int13 
Bits 31:29 = 1 Mail box interrupt on pin B_IRQI_ or _int2 
Bits 31:29 = 2 Mail box interrupt on pin B_IRQ2_ or _int3 
Bits 31:29 = 3 Mail box interrupt on pin B_IRQ3_ or _intS 
Bits 31:29 = 4 Mail box interrupt on pin B_LIRQ4_ or _int8 
Bits 31:29 = 5 Mail box interrupt on pin B_LIRQ5_ or _int9 
Bits 31:29 =6 Mail box interrupt on pin B_LIRQ6_ or _intl1 
Bits 31:29 = 7 Mail box interrupt on pin B_LIRQ7_ or _intl3 


Bits 28:24 =0 Default rerun, cycle 16 states 
Bits 28:24 = 1 cycle 17 states 
Bits 28:24 =2 cycle 18 states 
Bits 28:24 = 3 cycle 19 states 
Bits 28:24 = 4 cycle 20 states 


~ 
~ 


Bits 28:24 = 31 cycle 47 states 


7.11 Bus Locker 


A bus lock function provides a way to enable the CPU to do an atomic Read-Modify-Write (RMW) to 
its on-board memory without being interrupted by an incoming RMW from another VME Master. This 
function is only used when the card is running together. with one or more external CPU cards 
(multiprocessing). In these cases, message passing is done through shared memory locations that need to 
be accessed in a defined way. 


The bus locker is used to lock the VMEbus before a VME RMW cycle is executed to prevent a deadlock 
situation between two VME Masters. A deadlock situation can occur when two VME Masters want to 
perform RMW cycles at the same time. : 


7.11.1 VME Bus Locker Register 


In a non-multiprocessing application, this register should be left alone. When used, bit 24 of the register 
should ALWAYS be SET for each update, to guarantee a consistent bus arbitration behavior. 


a 
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7.11.2 Initialization 


All bits are initialized to 0’s. Thus, the VME bus locker is inactive and does not affect the card’s bus 
arbitration. 


Table: 7.14 Bus Locker Register Bit Definitions 











This bit indicates the VMEbus is owned. 
No external VME card can access memory. 
Bit is read only, a write to this bit is ignored. 


29 

28 This bit is ignored, and is read back as 0. 

: 
Once owned, it is held. 


This bit enables the Bus request function. 
It should only be set for multiprocessing applications. 
If set, it should never be changed (unless system is restarted). 






ik 
oO = 










NTN wv 
- AaAITastTya 










| 
In multiprocessing applications, update the register at the system initialization time by writing 0x01 to the 
register. The procedure for accessing an on-card memory location is: 


1 Disable all interrupts. (VME IACK cycles need to acquire control of VME.) 
2. Request VMEbus locking by writing 0x3 to the register. 

3. Read register and check bit 31 to until VMEbus is owned and locked. 

4. Do Read-Modify-Write (RMW) (atomic Load-Store) to on-card memory. 

5. Unlock VME by writing 0x1 to register. 

6. Enable all interrupts. 


NOTE: If the VME is not unlocked in time, other accesses might time out causing a system crash. 
Always unlock VME as soon as possible after the RMW is completed! 


NOTE: VME interrupts must be disabled during the bus locking procedure to prevent potential deadlock, 
since VME IACK cycles requires access to VME. Interrupts could otherwise cause a deadlock situation 
if it happens while the bus is locked. 
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7.12 Interrupt Handler 


The interrupt handler can selectively support all interrupt levels. These are enabled through the VME 
Interrupt/Bus Arbiter register. Note that this register is a replacement for a jumper and should normally 
be fixed depending on the VME Interrupt handler configuration. Run-time enabling of the interrupts are 
nomally done with the Interrupt Enable register, see the System Specification. 


7.12.1 Interrupt Enable/Bus Arbiter Mode Register 

This register enables VME interrupts to be fed to the Interrupt logic in the S-4 MMU chip. Only 8-bit 
accesses should be used, 16- or 32-bit accesses are not acknowledged, resulting in a bus error time out. 
The Interrupt Enable Register can selectively enable all VME interrupt levels. 

7.12.1.1 Interrupt Enable Register Initialization 

At initialization of the Interrupt Enable register, bits 31:25 are set and bit 24 is reset, enabling VMEbus 
interrupts and setting arbiter mode to single level arbitration (SGL). Tables 7-15, 7-16, and 7-17 provide 
more detailed information about the Interrupt Enable register. 


NOTE: This register replaces on-card jumpers. Changes to this register should only be done at system 
initialization time, and should not be changed at a later time unless the system is restarted. 
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NOTE: If VME interrupt level 7 or 6 is needed with VME there is a conflict of the floppy and audio 
ports interrupts. Either the audio or floppy driver must be commented out of the GENERIC.VME and 
GENERIC_SMALL.VME to disable one. Remember to copy the files before modifying them. Search 
the GENERIC. VME and the GENERIC_SMALL.VME files in the .conf directory for audioamd. Use the 
"#" pound symbol at the head of the line to comment out either the audio or fd line. Then rebuild the 
kemel. See the readme file in the .conf directory for further details. 


NOTE: Enabling the bus arbiter function is done via a jumper (Slot 1 jumper). 


7.13, Bus Requester 


The Bus requester is an ROR requester. It releases the bus when other VME Masters/Requesters requests 
the bus. The SPARC CPU-2CE can only request on Bus Request level 3. 


7.13.1 Bus Arbiter 


A Single Level Arbiter (level 3) and a FAIR Arbiter are provided. Note that the arbiter should be enabled 
only if the card resides in slot 1. (Slot1 jumper.) 


In arbitration mode, locked arbitration is detected and released by the arbiter after 3.3 ms. The Bus arbiter 
then drives BBSY active for the minimum period required by the VMEbus spec. This is to prevent 
requesters that in the mean time have decided to withdraw their requests to be able to do so. Note that 
a withdrawal of a VME Request normally is in violation of the VME Specification. (Rule 3.11). 


7.14 Bus Time Out Period 


There are two time out parameters in a VME cycle in addition to the On Board Bus arbitration timer: 
Rerun Time Out and Abort. 


7.14.1 Rerun Time Out 


If the time from the onboard Master cycle starts until the VME slave responds with a DTACK exceeds 
1.6 us, the cycle is rerun by the IU so high-priority devices can get on the Sbus. In the mean time, the 
Master cycle and all output signals is frozen, ignoring any DTACK coming in. When the cycle is rerun, 
it is reconnected again. 


7.14.2 Abort 


With the onboard master setup in slot 1, two Stages of the access exists. If the bus is not owned, it has 
to be acquired. Then the actual VMEbus cycle can start. A onboard or offboard Master cycle times out 
after 300 us. That means, the response time from another VME slave including the time for acquiring the 
bus must be less than 300 us. 


If the VMEbus is not owned when an abort occurs, the bus requester keeps the VMEbus Request asserted 
even though the CPU cycles has been aborted. It then asserts a dummy Bus Busy (BBSY) when the 
Bus Grant is received. This is to comply with VME mule 3.11. 


If the bus is owned when the abort takes place, a Bus Error is generated. This Bus Error would normally 
be generated by an accessed VME slave. This is to comply with VME rule 2.48. 
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7.15 VMEbus Watchdog Timer 


The SPARC CPU-2CE has a VMEbus watchdog timer to monitor the operation of the VMEbus. This 

function prevents the VMEbus from being locked when a Master accesses a nonexisting VME slave and 

when the master doesn’t have its own bus time-out circuit. A VMEbus error occurs if a DTACK is not 

generated within 300 microseconds (fixed) after a Data Strobe is asserted on the VMEbus. This is only 
~ active if Slot 1 function is enabled. 


7.16 System Reset and the Reset Switch 

On power up, the CPU card generates SYSRESET for a minimum of 200 ms, if the Slot! jumper indicates 
the card resides in slot 1. Incoming VMEbus resets always generate an on-card reset. 

7.16.1 Sources for a System Reset 

The sources of a system reset are listed below: 

¢ Power-on Reset. 

e Watchdog Reset. 

e Software Reset. 

NOTE: When the SPARC CPU-2CE is reset, the “daisy-chained" VME signals are not passed on 
for the duration of the reset cycle, regardless of the SPARC CPU -2CE’s configuration (Slot 1 or 
non-Slot1 device). 

“The Power-On Reset" 

On power-up, the SPARC CPU-2CE Board generates a sysreset on the VMEbus for a minimum of 200 
ms if it is configured as the slot 1 (VMEbus system controller) CPU. All SPARC CPU-2CEs on the 
VMEbus are reset in a system reset. 

"The Reset Switch" 

The Reset is located on the front panel of the card, labeled Reset. The switch rests in a null position. 
When it is activated, a reset procedure is activated that is performed by the VME Gate Array. If the board 
is configured as the slot 1 CPU, a VMEbus reset will be generated to reset all other non-slot 1 SPARC 
CPU-2CEs. For additional information, see the chapter VMEbus Interface in this manual. 

"The Watchdog Reset" 

The watchdog error is the result of a double bus error as detected by the SBus Controller on a SPARC 
CPU-2CE. If this occurs, an on-board reset is generated, and if the SPARC CPU-2CE is configured as 


the slot 1 controller, a VMEbus reset will be generated to reset all other non-slot 1 devices on the 
VMEbus. 
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"The Software Reset" 

As the name implies, this reset is generated by a SPARC CPU-2CE through a software trap which 
generates an on-board reset. If the board is configured as the slot 1 CPU, a VMEbus sysrest signal will 
be generated to reset all other non-slot 1 SPARC CPU-2CEs. 

7.17 Jumper 


A’ jumper is used to set the VME Interface for slot 1. The default sets the board as a VME slot 1 card. 
If jumpered, the SPARC CPU-2CE operates as the VME system arbiter and slot 1 card. 


Table 7.17 lists the function of the various jumper settings. 


Table: 7.17 Slot 1 Jumper & Functions 


L VME System Clock Enabled. 
¥ VME IACK Daisy-chain Driver | Enabled. IACKIN drives IACKOUT. 


SYSRESET Generates VME SYSRESET. Does not generate VME 
SYSRESET. 


7.18 Programmable Register Settings 

















VME Interrupt Handler Defines which interrupt levels to handle. 





Defines what type of VME Bus arbiter (only if the card resides 
in slot 1). ; 


| | 
1 A32 Map Register Defines where to map the CPU Master Address Space of 512 | 
) 


7.19 VME Interrupt Monitor Register 


SPARC CPU-2CE features a VMEbus Interrupt Monitor Register which provides a quick way to determine 
the source of the interrupt‘on the IU. The Monitor register is a direct status of the VME interrupt lines. 
Only byte reads to this register are permitted. The VMEbus Interrupt status is contained in bits 31:25. 
Other operations to this register result in a bus error time-out. 


Tables 7-19 and 7-20 list more detailed information about the Interrupt Monitor register. 
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Table: 7.19 VME Interrupt Monitor Register Address 


Spe ea Moat | 










| 
| 





NOTE: Bit 24 set to a one sets the requestor to Fair Mode. A bit set among bits 31:25 indicates a 
pending interrupt. 


7.19.1 Fair Mode Requester . 


The SPARC CPU-2CE includes an optional fair mode requester bit (Bit 24 of the Interrupt Monitor 
register) to allow Bus Faimess operations when the CPU is used in a multiprocessor environment. This 
allows VMEbus masters in the system to have equal access to the VMEbus. 


With the Fair bit set, the VME interface controller asserts a VME request only when no other bus request 
is pending. Resetting bit 24 of the Monitor register disables this feature. 


7.20 VME IACK Cycles 


When the SPARC CPU-2CE is set up to respond to vectored VME interrupt requests, it drives the [ACK 
line to acquire the interrupt vector from interrupting devices though software routines. A device space 
operation is used by the Interrupt handler to generate an Interrupt Acknowledge cycle. The operation is 
done only by doing a Device Space byte read at location OxEFE0000X with Address bits 3 to 1 set to the 
VMEbus interrupt level being acknowledged. A 16- or 32-bit access is not acknowledged and results in 
a bus error time-out. By doing this, an acknowledge process is started by first acquiring the bus, then by 
driving the IACK signal at the same time as with other control lines such as AS*, DS*, A1-3, etc. 


NOTE: An access to these seven addresses are not to an on chip register, but instead to execute a VME 
Interrupt Acknowledge cycle, acquiring the Interrupt Vector from the interrupting device. 
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Tables 7-21, 7-22, and 7-23 provide more detailed information about the VME mail box register, [ACK 
cycles registers, and responses. 


Table: 7.21 Mail Box Register Address 


| Tye i Device Address — _Physical Space 


1 


| VME Int. Vector 

| A[3:1]=VME Int. level. 
| 

| 

-= 


AO=1, Read, only 8-bit 






access should be used. 








-bit Interrupt Vector from interrupting VME Device Level A(3:1) 


This translates into the following interrupt responses: 


Table: 7.23 _VME IACK Cycles Interrupt Responses 


Acknowledging VME Interrupt Device Address _ | 











a 


7.20.1 Daisy Chain IACK Driver 


Since the SPARC CPU-2CE does not have the capability to interrupt the VMEbus through the VME . 
interrupt request lines, it does not provide interrupt vectors at all. Thus, it drives the daisy chain 
IACKOUT when an IACKIN is active. When set up as a slot 1 card, it drives the LACKOUT as soon as 
the non-daisy chain IACK signal is active. 
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7.20.2 Master Cycles 


Ideal VME slave accessed (30 ns DS to DTACK response). Bus already owned. No lingering DTACK 
or AS. A Master cycle is 9 cycles, corresponding to a theoretical 9 MB/s bandwidth for back-to-back 


cycles. 


7.20.3 Slave Cycles 
Ideal VME master (0 ns DTACK to DS response). Fast Sbus grant (two clock periods). 


Table 7.24 provides more information about the duration of slave cycles and the theoretical bandwidth. 


Table: 7.24 Slave Cycles Duration and Theoretical Bandwidth 


Cycle Duration (ns) Theoretical 
Bandwidth 


Single Read 560-630 ns 6.9 0 7.9 MB 
510-580 ns 631072MB | 














7.21 Bus Arbitration 


Table 7.25 lists the characteristics for single-level and Fair arbitration. 


Conditions 


Single Level Arbiter No VME master owns the bus, Bus Locker disabled. 
VME Bus Request to VME Bus Grant: 2 Cycles. 


No VME master owns the bus, Bus Locker enabled. 


VME Bus Request to VME Bus Grant: 3 Cycles. 


Round-Robin Arbiter No VME master owns the bus, Bus Locker disabled. 
VME Bus Request to VME Bus Grant: 2-5 Cycles. 


No VME master owns the bus, Bus Locker enabled. 
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7.22 Interrupts 


Table 7-26 defines the interrupt sources and their levels: 


Table: 7.26 VME Interrupt Levels and Sources 







SYSFAIL. _ aires atl 
Memory: Parity Error ECC Uncorrectable Error 


VME Level 7 Audio 
VME Mailbox interrupt 


a 


14 













aE 
a {8 
Be 
Sif 
So 








VME Level 3 Ethernet, SBUS 4 | 


| / 
; 
: 
BY 


All type 1 devices defined in the architecture, including the serial ports, use autovectored interrupts. 


The interrupt register in device space enables all interrupts, causes software interrupts, and enables 
specified interrupts. It is described in the chapter Device Space. The memory error registers in system 
space, provide information about any memory errors that occur. They are described in the chapter System 
Space. 





Page 7-26 FORCE COMPUTERS 


SPARC CPU-2CE Technical Reference Manual Hardware 


7.23 Example of a VME System 


Figure 7-1 is a diagram of a sample VME system with two SPARC CPU-2CE cards, a third-party Ethemet 
card, and a third-party SCSI card. The text below describes how this system configuration should be 
defined and implemented. This example is generic and is provided only as a guide for understanding the 
SPARC CPU-2CE VMEbus. 


Figure: 7.1 Sample VME System Diagram 


Slot 1 Slot 2 Slot 3 Slot 4 
A B Cc D 


oe 
JAGKDO 


i oe 
Reques 





Board A in slot 1 is a SPARC CPU-2CE with the slot 1 functions enabled (Arbiter, JACK Daisy Chain 
driver, SYS Clock Driver). It is an Interrupt Handler for level 1-3. Board B is also a SPARC CPU-2CE 
with the slot 1 functions disabled. It is an Interrupt Handler for level 4-7. Board C is an Ethernet card 
with a Slave and an Interrupter. Board D is a SCSI card with DMA capabilities. It has a Master, a Slave 
and an Interrupter. 


Board A needs to start a disk transfer by writing to command registers in card D. But first he has to 
acquire the bus. His Master orders the on card Requester to get the bus. The Requester asserts [BR]. 
If no one owns the bus, indicated by an inactive [BBSY)], the arbiter grants the bus with [BG]. Board A’s 
Requester receives this, assert [BBSY] and allow his Master to start a bus cycle. 


If another card ’s Requester was requesting the bus at the same time with a [BR], card A would still get 
it since the bus grant from the arbiter in slot 1 is passed from card to card via a Daisy Chain 
[BGIN,BGOUT] and card A is the first card in the Chain. 


Board A’s Master asserts addresses, data and then strobe [AS] and [DS(1:0)). 


Next, card D’s Slave detects that the cycle is aimed at him and respond with a [DTACK] once the data 
has been captured (the write to the command register). The SCSI card starts the disk access and when 
he has filled his buffer with data, activate his Master. The Master requests the bus via it’s on-card 
Requester. 
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The SPARC CPU-2CE requester is of Release On Request type, so he keeps the bus with [BBSY] until 
someone else asks for it. When Board D’s Requester requests the bus, Board A’s Requester drops 
[BBSY]. Now the Arbiter can grant the bus to card D with a [BG]. 


Board D acquires the bus asserting [BBSY] and the Master can start a DMA transfer to card A’s on card 
memory via A’s Slave. the Slave responds with a DTACK for every cycle. Once the whole transfer is 
complete, card D asserts interrupt 3 via his interrupter signaling he’s finished. 


Board A's interrupt handler is activated and does an Interrupt Acknowledge cycle. This cycle is almost 
identical to a Master read, but instead of reading data, the interrupt vector is read. [[ACK] is asserted to 
signal an IACK cycles, and address bits 1-3 indicates what level the IACK cycle is responding to. 


[LACK] from any interrupt handler is passed to slot1, where the back plane directly connects it to the start 
of the [IACKIN/IACKOUT] daisy-chain. This is done to enable interrupt handlers to be spread out on 
different cards if needed. The IACK Daisy Chain Driver in slot 1 drives the chain. Board B is not an 
interrupter and therefore always passes [L[ACKIN] to [I[ACKOUT]. 


Board C passes the incoming [I[ACKIN] to its [ACKOUT], unless he is interrupting on the same level 
at the same time. If so, he does not pass the [IACKIN] signal, but instead respond to the IACK cycle 
with a DTACK and his vector, different from card D’s. In the mean time, card D would not see any 
[IACKIN] and therefore just keep his interrupt asserted until card C passes it on. 


Board D’s interrupter responds to an IACK cycle with the corresponding bits set to the level he is 
interrupting on. Board A jumps to the disk card interrupt routine, with the understanding that the disk 
transfer has finished and now is ready and stored in the DVMA buffer. The transfer is complete. 


7.24 VMEbus Device Driver 


7.24.1 VMEbus Device Driver System Calls 


The VMEbus Device Driver supports the "usual" system calls: open(), close(), read(), write(), 
ioct1() andmmap(). Consult your SunOS documentation for detailed information regarding the general 
use of these functions. 


When making calls to these functions (in reference to the memory/devices managed by the VMEbus 
Device Driver) the following points are of interest: ees 


e open () verifies that the minor device number, of the file you are opening, is one of the 
following: 


VME16D16 VME16D32 
VME24D 16 VME24D32 
VME32D16 VME32D32 


These constants are defined in the header file vme.h. 


-_—_—_—_eoeeee eee 
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° read() and write () will not attempt to read past the end of the valid space defined by 
the minor number of the "file" you are attempting to read. In other words, attempts to 
read() or write() past the address Oxffff when using a file handle opened in A16 
space will not be attempted by the VMEbus Device Driver. Likewise, read() and 
write () will not read past the address Oxffffff in A24 space. 


e The following operations are defined for an ioct1() call: 
VME_SET_REG Write to a VME interface specific register. 
VME_GET_REG Read from a VME interface specific register. 
VME_RDSWITCH Read the current state of the HEX switch. 
VME_WRLEDS Write to the front-panel LED's. 


VME_ENA_DIS_VME32 Enable full 32-bit address access or place the VME 
interface into CPU-1E compatibility mode. 


VME_GET_PHYS Translate a DVMA address into its corresponding VME 
physical address. 


The labels described above are defined in vme.h supplied with the VMEbus Device 
Driver. A sample application, called v_rw.c, that uses each of these ioct1() Calls is also 
supplied with the VMEbus Device Driver. Please refer to these files for detailed 
information. 


. The S4-VME interface device has limitations when used to access the A32 space which 
must be taken into account when assigning addresses to VME peripheral devices on the 
VMEbus. These limitations are associated with hardware and cannot be fixed by software 
(either the VMEbus Device Driver or the application software). 


The VMEbus interface chip on the CPU-2CE directly decodes only 29 address bits 
resulting in what can be described as decoding a series of eight 512 megabyte "windows" 
(there is additional hardware to assist in distinguishing which "window" is being used). 
The VMEbus interface chip always interprets the upper 16 megabytes of each of these 
"windows" as A24 and Al6 space. Thus, one cannot map the following VMEbus 
addresses into A32 space: 
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FORCE COMPUTERS Page 7-29 


Hardware SPARC CPU-2CE Technical Reference Manual 


~ot 


Table 7.27 A16 - Only Access 


End Address 


==} 


| 
| 
| 
| 
| 
| 





7.24.2 VMEbus Address Modifiers 


Program/Data/Block Transfer Address Modifiers 


The CPU-2CE will generate only the Data Address Modifier Code. The Program and Block Transfer 
Address Modifier Codes are not supported. 
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Supervisory/Non-Privileged Address Modifiers 


The CPU-2CE can generate either the Supervisory or the Non-Privileged Address Modifier Codes. This 
is controlled by the Integer Unit’s (IU) Processor Stat Register (PSR). 


Typically a user's application will operate at a "non-privileged” level resulting in the assertion of the User 
Address Modifier Code when the users’s application access VMEbus addresses that have been allocated 
by the mmap() system call. If the user’s application is a driver that operates at the same privilege level 
as the kernel the Supervisor Address Modifier Code will be asserted when that driver accesses VMEbus 
addresses. 


Accesses to the VMEbus made within the kernel operate at a "privileged" level and will result in assertion 
of the Supervisor Address Modifier Code. This is the case when one uses the read() and write () 
system calls to access a VMEbus device. If the user uses the mmap call to create a pointer the VME AM 
code issued will reflect the current privilege level of the calling program. 


Extended/Standard/Short Address Modifiers 


The CPU-2CE may generate the Extended, Standard or Short Address Modifier Codes with the following 
restrictions: 


Table: 7.29 Address Modifier Codes 


| Address Modifier 
[extended (A32) | 0x09,0x0D | No Unaligned transfers are allowed _| 
| Standard (A24) 0x39, 0x3D No Unaligned transfers are allowed 


| Short (A16) 0x29, 0x2D No Unaligned transfers are allowed 










7.24.3 VMEbus Device Driver Limitations 


Floppy and Audio Interrupt Conflicts 


VMEbus IRQ6 and the standard SunOS floppy disk device driver cannot be used simultaneously. 
Likewise, VMEbus IRQ7 and the standard SunOS audio device driver cannot be used simultaneously. 


The floppy and audio device drivers will not share their respective interrupts with other device drivers 
because they use Programmed I/O to complete their tasks, rather than DMA. Programmed /O is relatively 
slow, therefore, these device drivers reserve their corresponding interrupt levels for exclusive use. Thus, 
if either of these devices is configured as part of the kemel their respective VMEbus IRQ cannot be used. 


EEE 
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Potential for SunOS Patches to Conflict 


Because several of the files supplied as a part of the VMEbus Device Driver are modifications of standard 
SunOS files there is a potential for SunOS patches to conflict with the VMEbus Device Driver. In 
general, it is best to consult FORCE COMPUTERS’ Technical Support to verify if a patch can be made 
to the SunOS kemel without interfering with the VMEbus Device Driver. 


If FORCE COMPUTERS has incorporated a specific SunOS patch there will be additional files supplied 
with the VMEbus Device Driver that should be used instead of the SunOS patch files. Using the FORCE 
COMPUTERS supplied files will insure that the patch is installed in a way that is compatible with the 
VMEbus Device Driver. The standard files supplied with the VMEbus Device Driver are based on the 
original, unpatched SunOS sources and do not incorporate any SunOS patches that have occurred since 
the specific release on which the VMEbus Device Driver is based. 


GENERIC.VME versus GENERIC_SMALL.VME 

Two kemel configurations are supplied with the VMEbus Device Driver. The GENERIC. VME 
configuration assumes all devices will be configured (including the floppy and audio device drivers) except 
for the ONC/VME Device Driver (see Section 8). 

When installing or configuring the VMEbus device driver using the GENERIC.VME configuration file 
you must ALWAYS ensure the file /etc/hostname.vm0 is created and contains the name of the VME node. 
This is similar to adding a second ethemet card. 


7.25 VME Programming Examples 


Two code examples are presented below, one written in FORTH, and the other written in C. These 
examples provide an indication to you on how to program for the VMEbus. 


Additional reference material required for a complete definition of the FORTH and C words used in the 
following code examples: SBUS Developer’s Kit, Sun Part No. 825-1219-xx, (Sun SBUS Information). 


7.25.1 FORTH Programming Examples 

Map the VMEbus to a Virtual Address 

The first FORTH example illustrates how to gain access to a known range of physical addresses on the 
VMEbus by mapping the desired VME address-range to a virtual address-range allocated from the Virtual 
Address Pool. 


The routine memmap maps a range of physical addresses within the specified "space" to a range of virtual 
addresses allocated from the Virtual Pool and retums the base virtual address which was allocated. 


ees 
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The "space" parameter can refer to On-Board Memory, On-Board 1/O, or any combination of VME-Bus 
Data-widths and Address-widths from among the following: D16 or D32 , and Al6, A24, or A32 


\ Initialization and constants. 


hex \ Set the numeric base for subsequent interpretation 

100.0000 constant my-vme-phys-addr \ Base-address of the desired VME range 
2.0000 constant my-size \ Size of the desired VME address~range 

O value my-virt \ Place-holder for the virtual address 


\ Now map the address-range: 


my-vme-phys~addr \ First parameter for memmap is the base-address 
(physical address) of the desired address-range 
vmed32a32 Second parameter for memmap is the "space". For 
this example, we are choosing 32-bit-wide data 
and 32-bit-wide addressing. The other valid 
options for this parameter, in this example, 
could be: vmed32a24 vmed32al6 
vmed16a32 vmedl6a24 vmedl6al6 


Third parameter for memmap is the size of the 
desired address-range. 


my-size 


ee he le te le 


road 


memmap The allocated virtual address is now on the stack. 


is my-virt \ Save it in the place-holder. 
You can now read from and write to any address in your specified 
range on the VMEbus, simply by reading from or writing to the 
corresponding virtual address. 


When you are done with the range, unmap the VMEbus address-range 
and return the virtual address-range to the Allocation Pool: 


a a Eo 


my-virt my-size free-virtual 


Map Local Memory to the VMEbus 


The next FORTH example illustrates how to map a range of your local memory to the VME slave port, 
allowing other VMEbus masters to obtain read/write access to your local memory in a DMA mode. This 
operation is normally undertaken by a device-driver under the /VME device-node, and, in fact requires 
the services of certain words which are methods within that'node, so this example will also illustrate 
various ways to arrange the required set-up for different situations. 


Common part of the set-up: Setting this CPU2CE’s slave-port. There isa 
configuration-variable called vme-slavemap whose value is 0 to 
(decimal) 15 (or Of hex) which identifies the slave-port number of 
the CPU2CE. If there is more than one CPU2CE, or other device capable 
of acting as a VME-slave, on the VME-bus, then each one must have a 
different and unique value for its slave-port number. If your board 
already has its vme-slavemap configuration-variable set to the proper 
value, then you will not need to repeat this sequence. We will assume 
that we are setting this CPU2CE’s slave-port number to 2. 


Pa a ae a a ae 


setenv vme-slavemap 2 Set the configuration-variable 


to the proper value. 


value in the configuration-variable. 


\ 
\ 
vme-slavemap vme-slavemap! \ Load the slave-port register with the 
\ 
\ Normally, this is done at startup time. 


OO 
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\ Set-up example 1: A device-driver under the /VME device-node, whose 
base-address is at 0c0.0000 and which operates with 16-bit data-width 
\ and 24-bit address-width 


0 0 ™ vmed16a24,0c0.0000" " /vme" begin-package 


\ The above begins the definition of a new device-driver package 
under the /VME device-node. It would normally precede the 
instructions which lead to the interpretation of the FCode 

for the device-driver in question. It supplies the essential 
information about the address and space at which the device 

is configured. The interpretation of the device-driver FCode 
would then be followed by the end-package command; however, 
those considerations are beyond the scope of this example. 


We will skip over such preliminaries as supplying the device's 
name or specifying the structure of its control registers. 


Since the present device is an offspring of the /VME node, it 
does not automatically have access to the required /VME 
methods. For convenience, we will define them here, as calls 
to the methods of the same name in the parent’s node -- ij.e., 
in the /VME node: 


AAA ZA aA DPA AMAA LZ 


map-in ( phys space size -- virt ) 
Map-out ( virt size -- ) 

dma-alloc ( n -—- vaddr ) 

dma-free ( vaddr n -- ) 

dma-map-in ( vaddr n cache? -- devaddr ) 
dma-map-out ( vaddr devaddr n -- ) 


map-in" $call-parent ; 
map-out" S$call-parent ; 
dma-alloc" $call-parent ; 
dma-free" $call-parent ; 
dma-map-in" $call-parent ; 
dma-map-out" S$call-parent ; 


my-address \ This will be the second value given in the second 
\ string parameter to begin-package prior to 
\ probing; in this example. 0c0.0000 


constant dev-address \ Make it a constant, to be consistent with 
\ the second set-up example 


my-space \ This will be the first value given in the second 
\ string parameter to begin-package prior to 
\ probing; in this example, vmedl6a24 


constant dev-space \ Make it a constant, to be consistent with 
\ the second set-up example 


\ Set-up example 2: The operator is doing some on-the-fly experimentation 
\ and merely wants to have the /VME device-node’s methods available: 


cd /vme \ Make the /VME device-node the top of the vocabulary 
context, and also the current vocabulary where 
definitions will be placed. The latter is not 
desirable, because words defined here will become 
methods of the /VME device-node, and OpenBoot 
does not permit you to forget a device’s methods. 
Since you are experimenting, you will likely want 
to forget and re-define your definitions as your 
experimentation progresses. 


DPA A AAA AZ 


also forth definitions \ This will leave the /VME device-node in 
\ your vocabulary search-order, but put 
\ the forth vocabulary back as the top 
\ of the context and as the current 
\ vocabulary for definitions. 


When you are finished, you can restore the normal search- 


\ 
\ order with the command-sequence: 
\ only forth also definitions 


ees 
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\ Again, we skip over preliminaries such as specifying the structure 
\ of the device’s control registers. 


0c0.0000 constant dev-address 
vmed16a24 constant dev-space 


\ The body of the example follows: 


Place-holder for the allocated virtual base-address 
of the device’s control registers structure. 


0 value dev-reg-base 


Place-holder for the virtual address we will use to 
access our slave port memory. 


0 value my-DMA-addr 


0 value dev-DMA-addr Place-holder for the address that the device, acting 
as Bus-Master, will use to access our slave 


port memory in DMA mode. 


227°7" AZ AAW 


\ Map-in the device’s control registers 


dev-address dev-space \ First two parameters for map-in 


reg-size \ Hypothetical constant specifying the size of 
\ the device’s control registers structure. 
map-in \ The allocated virtual address is now on the stack. 
is dev-reg-base \ Save it in the place-holder. 


\ Now we will allocate and map some memory for our slave port, 


\ "on the fly". 
dev-DMA-size \ Hypothetical constant specifying the size of our slave 
\ port memory. 


dma-alloc \ Allocate the memory; virtual address is now on the stack. 


is my-DMA-addr \ Save it in the place-holder. 


my-DMA-addr First parameter for dma-map-in is the virtual 


address which was allocated by dma-alloc 


Second parameter for dma-map-in is the size of 
the range to map to the VME slave port 


dev-DMA-size 


false The third parameter for dma-map-in specifies 


whether caching should be enabled, if available 
dma-map-in The address that the device, acting as Bus-Master, 
will use to access our slave port memory, 
is now on the stack 


BA OP BL LEAS LF 


is dev-DMA~addr \ Save it in the place-holder. 


\ Load the address that the device, acting as Bus-Master, will use 


\ to access our slave port memory, into its appropriate control 
\ register. 
dev-DMA-addr \ Address the device should use... 


dev-reg-base Base-address of the device’s control registers 


\ 

>dev-addr \ Hypothetical word to adjust the base address to 
\ the offset for the Device-Address Register. 
\ 


- 


Store the address in the Device-Address Register 


a 
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\ The device can now read from and write to the VME-bus address held in 

\ dev-DMA-addr (and copied to its Device-Address Register) to access 

\ the CPU2CE’s slave port memory. The CPU2CE can access the same memory 
\ by using the virtual address held in my-DMA-addr When you are done 
\ with this device’s access to the VME slave port, unmap things and 

% return the virtual address-range to the Allocation Pool: 

my-DMA~addr dev-DMA-addr dev-DMA-size dma-map-out 


my-DMA-addr dev-DMA-size dma-free 


\ Map-out the device’s control registers, now that you’re done 


dev-reg-base reg-size map-out 
0 is dev-reg-base 


Map an SBUS Address to a Virtual Address 


The third FORTH example illustrates how to gain access to a known range of physical addresses within 
the SBUS (actually, an known offset from the start of the SBUS) by mapping the desired address-range 
to a virtual address-range allocated from the Virtual Address Pool. 


0010.0000 constant my-SBUS-offset \ Base-address of the desired SBUS range 
0000.4000 constant my-SBUS-size \ Size of the desired SBUS address-range 


0 value my-virt \ Place-holder for the virtual address 


my~SBUS-offset sbus my-SBUS-size memmap is my-virt 


\ memmap can also be used with the following non-VME spaces: 


\ obmem obio 

\ You can now read from and write to any address in your specified 
\ range on the SBUS, simply by reading from or writing to the 
\ corresponding virtual address. 

\ When you are done with the range, unmap the SBUS address-range 

\ and return the virtual address-range to the Allocation Pool: 


my-virt my-SBUS-size free-virtual 


7.25.2 C Programming Example 


The C example below shows how to open a VME space and obtain a virtual pointer so that the VME 
space can be read/written to. 


In the Unix environment several options are available to the programmer. The VME-bus supports 16, 24, 
and 32 bit addressing, along with 8, 16, and 32 bit data transfers. In /dev several special files are 
provided that allow for the different configurations. For example, vme24d32 provides a 24 bit address 
with 32 bit data transfers. These special files can be opened and seeks performed. (See MEM in section. 
4S of the manual pages) However it is usually more efficient to use pointers. A pointer to an opened 
special VME file can be obtained using mmap(). (See MMAP in section 2 of the manual pages) 


#include <stdio.h> 
#include <fentl.h> 
#include <sys/types.h> 
#include <sys/mman.h> 
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#include <vme.h> /* important VME driver definitions */ 


main(argn, argv) 
int argn ; 

char **argv ;? 

{ 


int fd, i, len, off ; 
off t addr ; 

caddr_t ptr ;/ 
unsigned short *p ; 
unsigned short pat ;7 


if (argn < 3) { 
printf("usage: %s addr len {[pat)\n", argv[0]) ; 
return ; 


pat = Oxaaaa ; /* assign a default pattern to be used */ 


/* 
* Get "addr" from the argument list. Convert that address to a 32k aligned 
* base address plus an offset ("addr" and “oft™). 
«/ 
addr = (int)strtol(argv[1], (char **)NULL, 0) ¢ /* get addr from argv */ 
off = (addr & Ox7fff) >> 1; /* extract offset */ 
addr &= Oxffff8000 ; /* align base address */ 


len = (int)strtol(argv[2], (char **)NULL, 0) ; /* get length of trnsfr */ 


if (argn == 4) /* get data pattern */ 
pat = (short)strtol(argv[3], (char **)NULL, 0) ? 


printf ("addr 
printf ("off 
printf("len 
printf ("pat 


Ox%x\n", addr) ; /* display the values */ 
Oxéx\n", off*sizeof(pat)) ¢ /* we are going to use */ 
d\n", len) ; 

Ox%x\n", pat) ; 


/* 
* Now open VME space as address 24 data 16 (VME24D16). 
* 


if((fd = open("/dev/vme24d16",O_RDWR)) == -1) { 
printf("error opening vme bus\n") ; 
return ; 


/* 
* Use mmap to obtain a virtual pointer to VME space. Then, convert the 
* pointer to an unsigned short for 16 bit reads and writes. 
* 
if((ptr = mmap(0, len, (PROT_READ|PROT_WRITE), 
MAP_SHARED, fd, addr)) == (caddr_t)-1) { 
printf("mmap failed\n") ; 
return ; 


} 
p = (unsigned short *)ptr 7 
/* 


* Write VME memory with the specified data pattern. Then, read the data 
* back and compare to the specified data pattern. 


ay 
for (i=0 ; i<len/2 ; i++) /* write "pat" to the VME space ey: 
*(pt+itoff) = pat ;¢ 
for (i=0 ; i<len/2 ; i++) { /* read VME space, look for “pat” */ 


if (*(ptitoff) != pat) { 
printf("fail location %x read %x exp &x\n", ptitoff, 
*(p+itoff), pat) ; 
break ; /* break out of read loop */ 
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Section 8 


ONC/VME 


The VMEbus provides facilities for data sharing between multiple processors on the same backplane, but 
custom programming is usually required to make use for those facilities. None of the standard commands 
for inter-processor communication (e.g. rlogin) are of any help without a separate network connection. 


ONC/VME corrects that problem by defining a way in which two or more machines on the same VME 
backplane can use the backplane as if it were an IP network interface. All of the standard TCP/IP 
networking facilities, including NFS, can then be used by any of the machines on that backplane without 
an Ethemet or other secondary interconnection between hosts. Any facilities specific to a particular sort 
of network (for instance, the UNIX etherfind utility) will not operate on an ONC/VME interface. 


ONC/VME allows you to connect multiple processors residing in the same cardcage without having to use 
the usual network equipment such as thick-wire Ethemet or a multiplexing device. 


ONC/VME uses the VME backplane as the network device. The processors share memory across the bus. 
A host leaves an intemet protocol (IP) packet in a known location in a processor’s memory, then signals 
the destination host that a packet is waiting. 

The processors must be able to export a section of local memory to an arbitrary VME address that is 
megabyte-aligned. Efficiency of the protocol is maximized if the processors are able to send and receive 
VME mailbox interrupts. 

8.1 Capabilities 

ONC/VME supports most TCP/IP applications. These include: 

° remote programs such as rsh, rcp, rlogin 

* telnet | 

* fip 

° Spray 

° nfs 

8.2 Using ONC/VME 

Once the configuration has been completed and the ONC backplane driver (vm0) is active, you can use 
this device as you would an Ethemet interface. Section 8.3 describes the steps required to set up and 


boot one or more client SPARC CPU-2CEs over the VMEbus backplane. Section 8.4 describes the steps 
required for two or more SPARC CPU-2CEs to communicate over the VMEbus. 


eer 
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8.3 Booting Over the VMEbus Backplane 
This section describes the steps required to set up and boot one or more client SPARC CPU-2CE’s over 
the VMEbus backplane. It also describes the required configurations for hardware, software, and the 
PROM/NVRAM. 
CAUTION If ypbind is desired, add the server and client CPU’s hostname to the Master YP 
Map or disable ypbind by entering: 

kill -9 <PID> 

You can find out the <PID> by entering: 


ps -axj | grep YP 


In the latter case, ypbind must be disabled because the server and the client CPUs are not known over 
the NIS Master database and when add_client (8) is run, the ethemet address of the client(s) will not 
be used correctly. 


8.3.1 Installation Example 


This installation example lists the variables that must be Setup prior to server and client ONC/VME 
operation. ‘ 


° Each SPARC CPU-2CE must be assigned an Intemet address for v0 and a corresponding 
hostname. This is a different address than that of ethernet le0. 


° Each SPARC CPU-2CE must be assigned a unique slave map address space in the range 
of 0-15 (vme-slavemap). 


Table 8.1 lists the names, values, and variables for the server CPU. Table 8.2 lists the names, values, and 
variables for the client CPU. 


Table: 8.1 Example Server Configuration 
) Hostname 


1 Internet Address: 
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Table: 8.2 Example Client Configuration 


— wd 
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8.3.2 Hardware Configuration 

Install two or more SPARC CPU-2CE cards into a VMEbus card cage. Make sure no CPU is plugged 
into a slot reserved for the P2 extended bus of another CPU (i.e. VSB). 

8.3.3 Software Configuration 


The SPARC CPU-2CE designated as the server must have server software installed when SunOS/Solaris 
software was loaded. 


Power cycle the system and put each SPARC CPU-2CE at the OK prompt 


’ 8.3.4 PROM/NVRAM Configuration 


The CPU-2CE must contain version 2.3.6 or higher ROM to work properly with ONC\VME. To determin 
your ROM’s version number do the following: : 


e enter the forthmon monitor 

¢ type .version at the ok prompt 

Several variables in the PROM/NVRAM must be set up in order to boot over the VME backplane. The 
(server CPU) must set vine-slavemap. 

Each client CPU must set the following NVRAM variables: 

* boot-device 

© vm-server-slavemap 

e ym-server-addr 

° vm-ip-addr 


The sections that follow list the PROM/NVRAM variables and show examples of how to set them. See 
section 2 for more detailed information about these parameters. 
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8.3.4.1 vme-slavemap 


Each SPARC CPU-2CE must be assigned a unique slave map address space (vme-slavemap) in the range 
of 0-15. 


Set the server’s NVRAM vme-slavemap variable to zero, as shown below: 


OK setenv vme-slavemap 0 


Set the client’s NVRAM vme-slavemap variable to a value between 1 and 15. The example below shows 
how to set the example client’s wme-slavemap: 


OK setenv vme-slavemap 1 


8.3.4.2 boot-device 
Set the client’s NVRAM boot-device variable to vmnet. 


OK setenv boot-device vmnet 


8.3.4.3 vm-server-slavemap 
Set the client’s NVRAM vm-server-slavemap variable to zero, as shown below: 


~ OK setenv vm-server-slavemap 0 


8.3.4.4 vm-server-addr 

Set the client’s NVRAM vm-server-addr variable to the Intemet address of the client’s server. 

The Internet address is made up of four hexadecimal numbers expressed in decimal form. For example, 
the Intemet address 199.9.9.1 converts to the hexadecimal value 0xc709090!. 


OK setenv vm-server-addr 0xc7090901 


8.3.4.5 vm-ip-addr 


Set the client’s NVRAM vwm-ip-addr variable to the Intemet address of the client. This entry also requires 
a hexadecimal form. 


OK setenv vwm-ip-addr 0xc7090902 
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8.3.5 Initializing the System 

Reboot the system. The clients will be in a loop requesting a rarp address, is a normal condition prior 
to installation completion. 

8.3.6 Files To Edit on the Server 

When the server is booted and running vmunix, edit or create the following files. You must become 
root to make these changes. The following changes assume you have installed the VME/ONC driver 
onto your system according to the insulation instructions provided with the driver. 

8.3.6.1 /sys/sun4c/conf/GENERIC.VME 


Edit the /sys/sun4c/conf/GENERIC.VME file and uncomment the entry for the ONC/VME driver, as 
follows: 


device vm0 

Uncommenting this line in the GENERIC. VME file causes the ONC/VME driver to be included in the 
kernel. The kemel must be reconfigured for this change to have effect 

8.3.6.2 /etc/hosts 


Edit the /etc/hosts file and add the Internet address. This should be the same address set into NVRAM 
ym-server-addr (0xc7090901 in our example below). 


120.40.35.3 server loghost 
199.9.9.1 server-vm <-- add this line 
199.9.9.2 client-vm <-- add this line 


Use the banner word at the prompt to determine your ethemet address. 


8.3.6.3 /etc/ethers 


Edit the /etc/ethers file and add an entry for the client’s ethernet address (8:0:50:1:0:3 in our example 
below). 


8:0:50:1:0:3 client-vm <-- add this line 
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8.3.6.4 ONC Driver Interrupt Conflict with the Audio and Floppy Divers 


The ONC/VME driver uses the VME Mailbox interrupt as part of the communication protocol. The VME 
Mailbox interrupt level, by default, is set to level 13 and may conflict with the Audio driver. 


The ONC/VME driver is not automatically configured in the GENERIC.VME or 
GENERIC_SMALL.VME files. If you wish to use the ONC/VME driver you must uncommente it from 
the GENERIC. VME or GENERIC_SMALL.VME files. Then you must to run the config utility using 
either GENERIC. VME or GENERIC_SMALL.VME to rebuild the kernel. 

If the ONC/VME driver is configured to include the Floppy or the Audio device drivers, then the Open 
Boot vme-rerun variable needs to be set. The VME Mailbox interrupt must be set at an IPL, Interrupt 
Process Level, level other than level 11 or 13. Interrupt levels 11 and 13 are reserved exclusively for the 
Floppy and Audio drivers. 

For example, to set the VME/ONC driver to use IPL level 9 type the following in Open Boot. 


setenv vme-rerun 0xa0 


8.3.7 Adding a Client 


The next step requires you to run add_client and answer the questions. Refer to the Networking and 
Communications Administration section for more detailed information. Enter the following: 


> /usr/etc/install/add_client -i 


Once the clients have been added, edit the following files on the server. 


8.3.7.1 /etc/hostname.vm0 
Edit or create the file /etc/hostname.vm0. 


server-vm <-- add this line 


8.3.7.2 /etc/bootparams 


Edit the file /etc/bootparams and substitute the server mount points with the correct server name (the 
one used in hostname.vm0). In each line of this file, change server to server-vm. 


client-vm root=server: /export/root/client-vm <-- Change this line 
client-vm root=server-vm:/export/root/client-vm <-- To this 
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8.3.7.3 /export/root/client-vm/etc/fstab 


Edit the file /export /root/client-vm/etc/fstab and substitute server-vm for each occurrence of 
server. 


server:/export/root/client-vm / nfs rw 0 0 <-- Change this line 
server-vm:/export/root/client-vm / nfs rw0 0 <-- To this 


8.3.7.4 /export/root/client-vm/etc/hosts 


Create the file hosts in the directory /export/root/client-vm/etc and add the Internet addresses 
of the server and client(s). 


199.9.9.2 client-vm <-- Add this line 
199.9.9.1 server-vm <-- Add this line 


8.3.7.5 /export/root/client-vm/etc/hostname.vm0 


Create the file hostname. vm0 in the directory /export /root/client-vm/etc and add the line shown 
in the example below: 


client-vm <-- Add this line 


Delete the file /etc/hostname.le0. 


cp /vmunix /export/rooy/client-vm/vmunix 


8.3.8 System Start-Up 

After performing all of the configuration and setup tasks, it is time to start up the system. 

° fasthalt the server 

When the server displays the OK prompt, enter reset, and reboot the system. 

The server should boot, and when it starts the network daemons, the slave CPUs should boot over the 
VME backplane. 

8.4 Activating ONC/VME 


This section describes the steps required to activate ONC/VME for communicating between two or more 
SPARC CPU-2CEs sharing the same VMEbus backplane. 


Refer to Section 7, for detailed information on configuring multiple CPUs in the same VMEbus backplane. 
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8.4.1 Setting Up a Private Network 
This section shows the steps necessary to set up a private network that allows two SPARC CPU-2CEs to 
communicate using ONC/VME. For our example, the host:] CPU shall be called ravel and the host:2 
CPU shall be called pink. 
Each SPARC CPU-2CE must be assigned a unique slave map address space (vme-slavemap) in the range 
of 0-15. Set the NVRAM variable vme-slavemap for each CPU. Set ravel’s vme-slavemap to zero and 
pink’s to one. At the OK prompt of ravel (host:]), enter the following: 

OK setenv vme-slavemap 0 


At the OK prompt of pink (host:2), enter the following: 


OK setenv vme-slavemap 1 


1. If ypbind is desired, add each host to the Master YP map or disable ypbind by entering 
kill -9 <PID> | 
You can find out the <PID>, by entering: 
ps -axj igrep yp 


In the latter case, ypbind must be disabled because the private network is not known over the NIS master 
database, only locally. 


2. Edit the /etc/hosts files on ravel and pink to include the following: 


19'9:.:9..9:52 ravel_vmip <-- unique hostname 
199.9.9.2 pink_vmip <-- for each CPU 


3. Edit or create the /etc/hostname.vm0 file on ravel to have the following line: 
ravel_vmip 


And on pink edit or create the /etc/hostname.vm0 file to have the following line: 

pink_vmip 

4. Activate vm0, VME-IP service, on ravel and pink by entering the following: 
ifconfig vm0 ravel-vmip execute this line on a ravel 


ifconfig vm0 pink-vmip execute this line on a pink 
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Verify that vm0 is active by entering ifconfig vm0 on each of the SPARC CPU-2CEs. 


Now that vm0 is active, functions such as spray, rlogin, fip, rsh, and rcp can be performed as if on an 
ethemet network interface. 


8.5 Theory of Operation 


The heart of the ONC/VME protocol is a region of memory, exported by a processor to a well-known 
address in VME space. Other hosts may examine and modify this memory region, which is in a 
predefined format. Packets are transmitted by copying them into the source host’s ONC/VME region, then 
notifying the destination host that a packet is ready. The destination host copies the packet into its own 
local memory (not its ONC/VME region) and acknowledges receipt of the packet. 


Whenever a host modifies another host’s ONC/VME region, it sends a VME mailbox interrupt to that host 
to signal that the host should examine its region and act on the changes. 


The ONC/VME protocol is defined for IP (Intemet Protocol) packets only. No other protocols (ARP, 
XNS, LocalTalk, etc.) may transmit packets over an ONC/VME network interface. 


An ONC/VME network, from a high-level point of view, looks like any other network interface, with the 
exception of the protocol restriction above. Broadcast packets are transmitted by sending them 
individually to all other active hosts on the backplane. 


8.6 Memory Usage 


The following subsections detail the layout and addressing of the data structures defined by the ONC/VME 
protocol. 


8.6.1 Addressing Scheme 


ONC/VME memory regions are accessible in VME 32-bit data, 24-bit address space. Each host is 
assumed to occupy 1 megabyte in this space. The first three-quarters of that megabyte are unused by 
ONC/VME, and can be used by individual systems for their own purposes. The ONC/VME memory 
region starts at the last quarter-megabyte (i.e., at offset $C0000) of each megabyte in VME A24D32 space. 
Since A24D32 space contains 16 megabytes, a maximum of 16 hosts are allowed in an ONC/VME 
network. 


Each host has a host number, unrelated to its IP address. A host number determines which megabyte 
contains that host’s ONC/VME region. The host number also determines the host’s VME mailbox 
address. VME mailboxes occupy VME A16D16 space. The first 16 bytes of that space contain the first 
8 mailboxes, at 2-byte intervals starting at location 0. The other 8 mailboxes are at location $8000 in the 
A16D16 space, also at 2-byte intervals. Hosts numbered 0 through 7 use the first set of mailboxes 
(multiplying their host numbers by 2 to get the address is A16D16 space,) while hosts numbered 8 through 
16 use the second set of addresses, multiplying the lower three bits of their host number by 2 and adding 
to $8000 to obtain the mailbox address. 
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Table 8.3 shows the layout of the ONC/VME memory region (also called VMIP space, for historical 


reasons). Brief descriptions of the fields follow. 





Page 8-10 





Table: 8.3 ONC/VME Region Layout 








= 


sneer one) | 


| 
| 
| 
| 
| 
| 
| 
| 


PE 
| 









Rapier) sat bas 9 oyweng war] 


State of host 15 
IP address of host 0 


4 adress of host 1 
ie ce IP address of host 15 
iegehe-Ps kant NS-SE} Valid-host flag for host 0 

[4 | Vatid-host tag for host 1 

as Valid-host flag for host 15 
[4 —__| Length of packet from host 0 | 
[4 | Length of packet from host 1 | 


N 





— 
N 
oo 


— 
Ww 
N 










bet 
w 
fo.) 













— 
N 






N 
wa 
an 






Ww 
i 
So 


| 
LS ooltcol a grist auirani eS anal 
Length of packet from host 15 : 

Contents of packet for host 0 | 

mw | Contents of packet for host 1 | 
| 

rs 
17604 1152 Contents of packet for host 15 | 


-_ 
pS 
~ 
an 





FORCE COMPUTERS 


SPARC CPU-2CE Technical Reference Manual ; Hardware 


SPARC eee ee 


8.6.2.1 Magic Number 

The magic number must be placed at the beginning of a host’s ONC/VME memory region, so that other 
hosts can probe to determine whether or not ONC/VME is active. The magic number also serves to 
identify the revision of the ONC/VME protocol. $3D26 is the magic number for version 1 of the protocol. 
8.6.2.2 Packet-Ready Flags 

When a source host is ready to send a packet, it sets a packet-ready flag in the destination host's region. 
A packet-ready flag is set if it’s nonzero. 

8.6.2.3 Host States 

A local host’s notion of a remote host’s state can have one of three values. State 0 means that the local 
host has sent a packet to the remote, but the remote hasn’t yet processed the packet. State 1 is set by the 
remote when it’s done copying the packet from the local host’s region. State 2 indicates that the local 
host knows that the remote has finished processing the most recent packet, and is ready to receive another. 
The host state is in network byte order. 


8.6.2.4 IP Addresses 


ONC/VME uses standard four-byte IP addresses. 


8.6.2.5 Valid-Host Flags 

The valid-host flags are provided as shortcuts for source hosts. They allow a host to quickly determine 
which of its peers are running the ONC/VME protocol. 

8.6.2.6 Packet Lengths 

When a source host has determined the length of the packet it wishes to transmit, it sets the destination 
host’s packet-length field to the size, including headers, of the packet. The packet-length fields are in 
network byte order. 

8.6.2.7 Packet Contents 

There is one packet buffer for each of the 16 hosts allowed by the protocol. The packet data, including 
headers, are copied into one of these buffers for transmission. 

8.7 Protocol Operation 


The following sections describe the operation of the ONC/VME protocol. 


OO 


FORCE COMPUTERS Page 8-11 


Hardware SPARC CPU-2CE Technical Reference Manual 


8.7.1 Initialization 


ONC/VME initialization occurs in three stages. 


8.7.1.1 Initializing the Hardware 


First, any hardware-specific initialization, such as memory allocation and mapping, is performed. This 
usually includes allocating memory for the ONC/VME region and performing whatever MMU-Specific 
functions are necessary to export the region to the appropriate location in VME space. Mailboxes should 
also be allocated, if necessary. 


8.7.1.2 Initializing the Local Region 


Once memory has been allocated for the local ONC/VME memory region, the region must be initialized. 
The packet-ready, state, valid-host, and length fields are zeroed out. The IP address of the local host is 
placed in the appropriate place in the region (appropriate meaning the IP address field whose number 
equals the local host number, host number 5 would set IP address number 5.) The host sets its own 
valid-host flag, in the same way. 


At-this point, the region is ready to be accessed by other hosts, so the magic number is set. The magic 
number should not be set until the IP address field is initialized. 


8.7.13 Probing for Remote Hosts 


For each of the other 15 possible hosts, the local host tries to read the start of the remote’s ONC/VM:: 
region. If the magic number is present, the local host copies the remote host’s IP address to the 
appropriate slot in its own region, and sets the remote host’s valid-host flag in the local region. The local 
host sets its notion of the remote’s state (i.e., the "state" entry in the local host’s region whose number 
corresponds to the remote’s host number) to two. The local host also places its own IP address into its 
slot in the remote host’s region, and sets its valid-host flag in the remote region. 


8.7.2 Sending a Packet 

When a host has a packet to send, it looks through its list of valid hosts. For each host marked as valid, 
the local host checks the remote host’s IP address against the packet’s destination address. If no addresses 
match, the local host should indicate to the process sending the packet that the destination host doesn’t 


exist. 


Assuming a match is found, the following steps are taken. Assume that "X" is the host number of the 
remote host. 


I. If the remote’s state (according to its state entry in the local region) is zero, queue the 
packet up for later transmission or discard it. 


ox Set the remote’s state to zero. 
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3. Copy the packet, including IP headers, into the local packet buffer corresponding to the 
remote’s host number. If there is non-IP header material at the beginning of the packet, 
it is not copied; only IP packets are placed in the packet buffers. 


4. Set the local length entry corresponding to the remote’s host number to the size of the 
packet. 

5: Set the packet-ready flag corresponding to the local host number in the remote’s 
ONC/VME region. 


Send a VME mailbox interrupt to the remote host. The contents of the mailbox are 
ignored. 


At. this point, the first stage of packet transmission is finished. It is usual to exit the 
network driver, though the protocol allows for synchronous operation if desired. 


Assuming the protocol is running asynchronously, when a mailbox interrupt is received by the local host, 
it does the following: 


1. Check its local packet-ready flags. If any are set, a remote host has a packet for the local 
host. See "Receiving a Packet," below. 


2 Check the states in its local region. If a state is 1, set it to 2, and send the next queued 
packet, if any, for the appropriate remote host. 
8.7.2.1 Broadcast Packets 
If a packet’s destination address indicates that it should be broadcast to the entire ONC/VME network, 
simply send the packet separately to each host marked as valid in the local region. 
8.7.3 Receiving a Packet 


Packet receipt is initiated by the mailbox interrupt. When a mailbox interrupt is received, the local host 
does the following: 


1. Check its local packet-ready flags. If mone are set, the mailbox interrupt is an 
acknowledgement of packet receipt; see the previous section. 


a For each packet-ready flag, copy the packet from the local host’s packet buffer in the 
remote ONC/VME region. The length of the packet is, of course, determined by reading 
the local host’s packet length entry from the remote’s memory. 


3. Set the local host’s state in the remote region to 1, meaning that the local host has 
received the packet and will no longer examine the remote’s region. 

4. Send a mailbox interrupt to the remote. 

5. Process the packet appropriately for the local operating system. 


a 


FORCE COMPUTERS Page 8-13 





Hardware SPARC CPU-2CE Technical Reference Manual 


Note that with the exception of setting the packet-ready flag, the sending side does not access the 
receiving side’s ONC/VME memory region. The receiver performs almost all the VME memory accesses. 


It is convenient, though not required, to set the remote’s valid-host flag in the local region whenever a 
packet is received, in case the remote was marked invalid temporarily (see "Error Handling” and "Shutting 
Down" below.) 


8.7.3.1 Shutting Down 


To remove a host from a ONC/VME network, set its valid-host entry in all remote hosts’ regions to zero. 
Set the local magic number to an invalid value. 


8.73.2 Error Handling 


If a host is removed from the network, remote systems will not be able to access its memory properly. 
This will usually result in a data access exception such as a timeout. The local operating system should 
handle such exceptions, noting when they occur during the processing of an ONC/VME packet. When 
an exception occurs during ONC/VME processing, set the valid-host flag of the offending host to zero, 
so that no further packets can be sent to that host. 
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